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
  • asp之家 网络编程 m.aspxhome.com