python解决八皇后问题(python2.7)

八皇后问题是计算机中极为经典的一个递归问题。在python中用生成器可以很方便地解决它。

先明确一些细节,产生的解可以用列表或元组保存,这里选择用元祖。元祖的索引充当行数,数值充当列数。

先定义一个验证冲突函数conflict:

>>> def conflict(state,x):
	l=len(state)
	flag=0
	if x in state:
		flag=1
	else:
		for i in range(l):
			if abs(x-state[i])==abs(i-l):
				flag=1
	if flag:
		return True
	else:
		return False

这里输入当前状态元组state,再输入下一行位置x,判断下一个放置棋子的位置是否与之前的皇后冲突。

 

有了这个函数我们就可以用python的生成器做递归:

def queen(num=8,state=()):
	l=len(state)
	for i in range(num):
		if not conflict(state,i):
			if l==num-1:
				yield (i,)
			else:
				for r in queen(num,state+(i,)):
				yield r+(i,)

我们先要明确queen函数到底是要做什么,输入棋盘大小num,再输入棋盘当前状态(默认为空),返回当前状态下剩余棋子排放位置。函数运行后r返回所有缺少i的可行棋盘状态,所以最后返回r+(i,),即最后结果。至于如何返回,靠的是递推一层层遍历。这一点有点烧脑,需要好好想。

结果:

 
>>> len(list(queen(8)))
92

 

 

 

 

 

 

 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值