python基于右递归解决八皇后问题的方法
作者:小萝莉 时间:2021-01-12 21:02:38
本文实例讲述了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]<8 and not Test(queen,n):queen[n]+=1
return queen[n]<8
def 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程序设计有所帮助。
标签:python,递归,八皇后
0
投稿
猜你喜欢
js判断某个字符出现的次数的简单实例
2024-04-16 10:33:24
HTML邮件的又一点思考
2009-05-06 13:33:00
浅谈Python2之汉字编码为unicode的问题(即类似\\xc3\\xa4)
2021-12-14 07:07:19
python的多线程原来可以这样解
2021-02-22 16:12:18
23个MySQL数据库安全使用技巧
2007-10-26 16:02:00
Python 从一个文件中调用另一个文件的类方法
2022-02-22 23:36:35
MySQL中的binlog相关命令和恢复技巧
2024-01-22 20:42:08
Python Web框架之Django框架Model基础详解
2023-11-04 22:07:00
Django restful framework生成API文档过程详解
2021-08-10 16:37:16
Python实现针对json中某个关键字段进行排序操作示例
2023-03-28 16:02:37
opencv实现图像缩放效果
2022-10-24 04:52:28
Python利用capstone实现反汇编
2022-08-08 17:50:52
MySQL定时任务EVENT事件的使用方法
2024-01-17 03:26:20
ASP开发中可能遇到的错误信息中文说明大全(整理收集)第1/2页
2010-07-02 09:50:31
对Python Pexpect 模块的使用说明详解
2022-10-24 02:14:09
用python实现操纵mysql数据库插入
2024-01-16 01:15:41
内容适应形式
2010-03-18 16:09:00
不要用强制方法杀掉python线程
2021-04-10 09:19:18
Python爬虫开发与项目实战
2022-04-21 03:10:32
ASP实现GB2312字符与区位码的相互转换
2009-12-28 10:27:00