python基于右递归解决八皇后问题的方法

本文实例讲述了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 true
def settle(queen,n):
”’这个负责安置第n(下标,0-7)行皇后,每次调用,皇后都至少会移动一步”’
queen[n]+=1
while queen[n]

Posted in 未分类

发表评论