时间:2021-05-22
本文实例讲述了python基于右递归解决八皇后问题的方法。分享给大家供大家参考。具体分析如下:
凡是线性回溯都可以归结为右递归的形式,也即是二叉树,因此对于只要求一个解的问题,采用右递归实现的程序要比回溯法要优美的多。
def Test(queen,n): '''这个就不用说了吧,就是检验第n(下标,0-7)行皇后的位置是否合理''' q=queen[n] for i in xrange(n): if queen[i]==q or queen[i]-q==n-i or queen[i]-q==i-n:return False return Truedef Settle(queen,n): '''这个负责安置第n(下标,0-7)行皇后,每次调用,皇后都至少会移动一步''' queen[n]+=1 while queen[n]<8 and not Test(queen,n):queen[n]+=1 return queen[n]<8def Solve(queen,n): '''这个负责解决第n(下标,0-7)行皇后的安置以及随后所有皇后的安置''' if n==8:#安置完所有皇后了,故输出列表 print queen return True#如果设为假,则会尝试所有的安置方案 else: queen[n]=-1#初始化第n行皇后的起始位置(起始位置-1,可安置在0-7) while Settle(queen,n):#如果成功安置皇后 if Solve(queen,n+1):#安置其余皇后 return True#成功安置,返回真 return False#失败,返回假if __name__=='__main__': Solve([-1 for i in range(8)],0)#列表的值可以随便设置,因为会初始化#虽然我们没有进行回溯,但事实上,我们每一个参数相同的Solve函数都尝试了多次#输出:[0, 4, 7, 5, 2, 6, 1, 3]#比回溯法容易多了吧希望本文所述对大家的Python程序设计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了Python基于生成器迭代实现的八皇后问题。分享给大家供大家参考,具体如下:问题:有一个棋盘和8个要放到上面的皇后,唯一的要求是皇后之间不能形成威
本文实例讲述了Python基于回溯法子集树模板实现8皇后问题。分享给大家供大家参考,具体如下:问题8×8格的国际象棋上摆放八个皇后,使其不能互相攻击,即任意两个
本文实例讲述了C语言八皇后问题解决方法。分享给大家供大家参考,具体如下:1.概述:八皇后问题是一个以国际象棋为背景的问题:如何能够在8×8的国际象棋棋盘上放置八
本文为大家分享了python八皇后问题的解决方法,供大家参考,具体内容如下题目:给定一个N*N正方形棋盘,在上面放置N个棋子,又叫皇后,使每两个棋子都不在同一条
复杂度可能高了点--也没太注意我想了好久也找了好久没看到什么能够用python解决n皇后问题而且不调用递归的因为我不太能理解递归(尤其是到n层时)智商受限--i