python基于右递归解决八皇后问题的方法
本文实例讲述了python基于右递归解决八皇后问题的方法。分享给大家供大家参考。具体分析如下:
凡是线性回溯都可以归结为右递归的形式,也即是二叉树,因此对于只要求一个解的问题,采用右递归实现的程序要比回溯法要优美的多。
defTest(queen,n): '''这个就不用说了吧,就是检验第n(下标,0-7)行皇后的位置是否合理''' q=queen[n] foriinxrange(n): ifqueen[i]==qorqueen[i]-q==n-iorqueen[i]-q==i-n:returnFalse returnTrue defSettle(queen,n): '''这个负责安置第n(下标,0-7)行皇后,每次调用,皇后都至少会移动一步''' queen[n]+=1 whilequeen[n]<8andnotTest(queen,n):queen[n]+=1 returnqueen[n]<8 defSolve(queen,n): '''这个负责解决第n(下标,0-7)行皇后的安置以及随后所有皇后的安置''' ifn==8:#安置完所有皇后了,故输出列表 printqueen returnTrue#如果设为假,则会尝试所有的安置方案 else: queen[n]=-1#初始化第n行皇后的起始位置(起始位置-1,可安置在0-7) whileSettle(queen,n):#如果成功安置皇后 ifSolve(queen,n+1):#安置其余皇后 returnTrue#成功安置,返回真 returnFalse#失败,返回假 if__name__=='__main__': Solve([-1foriinrange(8)],0)#列表的值可以随便设置,因为会初始化 #虽然我们没有进行回溯,但事实上,我们每一个参数相同的Solve函数都尝试了多次 #输出:[0,4,7,5,2,6,1,3] #比回溯法容易多了吧
希望本文所述对大家的Python程序设计有所帮助。
热门推荐
10 八一幼儿祝福语大全简短
11 公司乔迁食堂祝福语简短
12 婚礼结束聚餐祝福语简短
13 儿媳买车妈妈祝福语简短
14 毕业送礼老师祝福语简短
15 同事辞职正常祝福语简短
16 恭贺新婚文案祝福语简短
17 金店立秋祝福语简短英文
18 婆婆高寿祝福语大全简短