八皇后问题python_python八皇后问题的解决方法

本文为大家分享了python八皇后问题的解决方法,供大家参考,具体内容如下

题目:

给定一个 N*N 正方形棋盘,在上面放置 N个棋子,又叫皇后,使每两个棋子都不在同一条横线上、竖线上、斜线上。一般我们都讨论8皇后,但是只要N > 4,都会存在解的。

分析:

方法1:根据定义来处理,即每往棋盘中放置皇后的时候,都要判断哪些位置可以放新加入的皇后,而哪些地方如果放置皇后的话,会造成冲突。我下面写的这个代码就是基于此。

方法2、我看了下别人的优化,主要是采用位运算来实现计算复杂度降低的,我没有用Python 实现这个,所以在这里挖一个坑。

代码:

代码里的注释有详细的说明,设定N值,即可返回一个符合要求的解。但是这个问题还有一个进阶,那就是讨论究竟会有多少个解,这就需要数论的知识了,而且我对这块数学没研究过,所以也没有代码实现。大家将就使用一下代码就好了。

class EightQueensPuzzle(object):

'''

八皇后问题求解

代码使用方法:

eight_q = EightQueensPuzzle(4, 5)

print "EIGHT QUEEDS PUZZLE:"

result = eight_q.eight_queens_puzzle()

for i in result:

print i

'''

def __init__(self, n, char):

self.n = n # 棋盘维度

self.char = char # 皇后标记字符

def init_chess_board(self, n):

'''

初始化一个棋盘,棋盘规格可以按参数 n 随意选定,一般都讨论八皇后,就选择 8

:return: 返回棋盘,是一个 8*8 矩阵

'''

chess_board = []

for i in xrange(0, n):

line = []

for j in xrange(0, n):

line.append(0)

chess_board.append(line)

return chess_board

def update_conflict_board(self, conflict_board, position):

for k in xrange(0, self.n): # 为行添加 1

conflict_board[position[0]][k] = 1

for id in xrange(position[0]+1, self.n):

conflict_board[id][position[1]] = 1 # 为列添加 1

if position[0] + position[1] - id >= 0: # 为左斜添加 1

conflict_board[id][position[0] + position[1] - id] = 1

if position[1] - position[0] + id < self.n: # 为右斜添加 1

conflict_board[id][position[1] - position[0] + id] = 1

def queens_conflict(self, conflict_board, position):

'''

当前棋盘的状态是 conflict_board, 判定如果在 position 位置给一个皇后的话,会不会出现问题。

如果有问题则返回 False,如果没有问题返回 True

'''

if conflict_board[position[0]][position[1]] != 0:

return False

else:

return True

def eight_queens_puzzle(self):

'''

给出一个八皇后的求解答案。

:return:返回一个结果并打印.

'''

import random

while True: # 不停寻找符合条件的八皇后排列

chess_board = self.init_chess_board(self.n)

conflict_board = self.init_chess_board(self.n)

for i in xrange(0, self.n):

flag = 0

for cnt in conflict_board[i]:

if cnt != 0:

flag += 1

if flag == self.n: # 如果已经1被填满了,说明这个答案错误

break

while True:

pos = [i, random.randint(0, self.n-1)] # 元组构成皇后的位置

if self.queens_conflict(conflict_board, pos): # 如果没有冲突

chess_board[i][pos[1]] = self.char

self.update_conflict_board(conflict_board, pos)

break

if self.char in chess_board[self.n-1]:

return chess_board

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/435068.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

arcgis中的python字符串比较

字段类型为字符串 jj为int类型 在使用python的ifelse时对字符串进行比较时并赋值&#xff0c;输出结果全部为1 正确代码如下 # -*- coding: utf-8 -*- z0 def a(td):tdtd.encode(utf-8);global zif(td低风险):z1elif(td中风险):z2elif(td高风险):z3elif(td极高风险):z4else…

禅道——需要我们斟酌

一则故事一个苦者对和尚说&#xff1a;“我放不下一些事&#xff0c;放不下一些人。” 和尚说&#xff1a;“没有什么东西是放不下的。”他说&#xff1a;“可我就偏偏放不下。”和尚让他拿着一个茶杯&#xff0c;然后就往里面倒热水&#xff0c;一直倒到水溢出来。苦者被烫到马…

【转】“线程间操作无效: 从不是创建控件的线程访问它”

经典解决“线程间操作无效: 从不是创建控件的线程访问它”在编程中经常会遇到在一个按钮中执行复杂操作&#xff0c;并将复杂操作最后返回的值加入一个ListView或ComboBox中候选。这个时候程序会卡&#xff0c;当程序员将这些卡代码放进线程(Thread)中后发现当对控件操作时出现…

python正则判断_Python 正则表达式

一、基础语法1.1 语法速查1.2 最简单的正则匹配学习正则一般是从 match 和 search 函数开始&#xff0c;推荐教程。matchmatch(pattern, string) 函数会从字符串的头部开始搜索&#xff0c;如果匹配到了 pattern 则将其结果存入 group 中&#xff0c;匹配到了几次就存入几次&am…

arcgis中字段计算器利用python比较大小

# -*- coding: utf-8 -*- z0 def numbersize(a,b):global zif(a>b):zaelif(a<b):zbelif(ab):zaelse:z99return z

程序员到底怎么了?

程序员到底怎么了&#xff0c;我们当然不否认有很多出色的程序员&#xff0c;他们生活的好&#xff0c;赚的也多&#xff0c;可是毕竟大多数都还是一般水平&#xff0c;很多还是挣扎在基本满足吃住的水平。特别深的问题&#xff0c;比如国家社会问题&#xff08;总有人会说我们…

python读取单波段影像dem

from osgeo import gdal import matplotlib.pyplot as plt ds gdal.Open(r"。。。\DEM1.tif") im_width ds.RasterXSize im_height ds.RasterYSize im_data ds.ReadAsArray(0, 0, im_width, im_height) plt.figure(figsize(20,18)) plt.imshow(im_data) plt.show…

qt int转换成qstring_「QT界面编程实例」创建颜色下拉框并改变窗体颜色(调色板)...

【实例】Qt创建窗体下拉框并改变窗体颜色&#xff1a;QPalette、QColor、QPixmap、QSize、QIcon、QStringList、QString本例是想创建一个颜色下拉框(颜色是自动从QColor中添加的)&#xff0c;当选择某个颜色时&#xff0c;改变对应窗体(控件)的颜色(背景色、字体颜色等)。主要函…

持久化雪花视图实例学习

【实例学习】在实践Pdf版书中P52的例子中&#xff0c;继续学习&#xff1a;NSMutableArray类The NSMutableArray class declares the programmatic interface to objects that manage a modifiable array of objects. This class adds insertion and deletion operations to th…

ubuntu12.04samba服务器配置

系统平台&#xff1a;VMware Workstation9.0 ubuntu12.04 首先要解决windows和linux网络连接问题&#xff1a; 在VMware Workstation9.0 “设置” 选项中&#xff0c;设置"网络" 网络连接1 选中“启用网络连接” 方式&#xff1a;NAT 网络连接2 选中“启用网络连…

arcgis字段计算器利用python按不同两列数据进行编号

示例 代码 # -*- coding: utf-8 -*- A=1 B=1 C=1 A1=1 B1=1 C1=1 A2=1 B2=1 C2=1 A3=1 B3=1 C3=1 A4=1 B4=1 C4=1 def a(name,bianhao):name=name.encode(utf-8);global A,B,C,A1,B1,C1,A2,B2,C2,A3,B3,C3,A4,B4,C4if(name==老虎洞村):if(bianhao==4):end="A"+str(A…

python抽卡游戏_【python爬虫】原神公测预抽卡活动自动化抽卡脚本(一小时免登陆)...

[Python] 纯文本查看 复制代码import requestsimport jsonimport time#pyinstaller -D -i favicon.ico crawl.pyclass Crawl():#初始化cookiesdef __init__(self):self.login_ticket "";self.account_id"";self.login_uid"";self.cookie_token&…

vs2010 sp1 安装 Silverlight4_Tools 提示 错误 解决办法

vs2010 sp1 在安装 Silverlight4_Tools 时提示我未安装相应版本的 vs 解决办法&#xff1a; HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\VisualStudio\10.0\Setup\VS\BuildNumber 将 "2052" 的值修改为 "10.0.30319"&#xff0c;然后安装Silverlight4Tools程序…

VMware Workstation网络连接的三种模式

经常要使用VMWare Workstation来在本地测试不同的操作系统&#xff0c;以前也搞不清楚网络连接三种模式&#xff0c;最近看了几篇文章才算明白。现总结如下&#xff1a; 1. VMware Workstation的虚拟网络组件 虚拟<网卡/网络适配器>&#xff1a;见下图。安装一个虚拟PC…

arcgis字段计算器利用python按两列要求编号

示例 代码 # -*- coding: utf-8 -*- A1 B1 C1 A11 B11 C11 A21 B21 C21 A31 B31 C31 A41 B41 C41 def a(name,bianhao):namename.encode(utf-8);global A,B,C,A1,B1,C1,A2,B2,C2,A3,B3,C3,A4,B4,C4if(namea):if(bianhao4):end"A"str(A)AA1elif(bianhao3):end"B…

python获取文件读写权限_Python 查看文件的读写权限方法

实例如下&#xff1a;# -*- coding: utf-8 -*-# author flynetcnimport sys, os, pwd, stat, datetime;LOG_FILE /var/log/checkDirPermission.log;nginxWritableDirs [/var/log/nginx,/usr/local/www/var,];otherReadableDirs [/var/log/nginx,/usr/local/www/var/log,];di…

dd , /dev/zero和/dev/null

dd 命令 功能&#xff1a;把指定的输入文件拷贝到指定的输出文件中&#xff0c;并且在拷贝过程中可以进行格式转换。可以用该命令实现 DOS 下的 diskcopy 命令的作用。先用 dd 命令把软盘上的数据写成硬盘的一个寄存文件&#xff0c;再把这个寄存文件写入第二张软盘上&#xf…

netpbm

netpbm是一款图形转换的工具。netpbm工具库格式转换命令.Netpbm是一个很好用的&#xff0c;很强大的命令方式图像处理程序&#xff0c;支持WINDOWS、LINUX及部分UNIX系统。将一幅png图像转成bmp格式。命令序列为&#xff1a;pngtopnm test.png > a.pnmppmtobmp -bpp24 a.pnm…

利用anaconda prompt打开jupyter notebook

切换盘符 到指定文件夹下 查看改文件夹下的文件夹 再其文件夹下打开jupyter notebook 或者 结果&#xff1a; 创建python3文件 编写代码&#xff08;运行代码快捷键ctrl enter​​​​​​​&#xff09;

rest接口_深度干货 | 测试REST服务接口

openEA开源社区开源&#xff0c;我们是认真的&#xff01;这里每天给大家呈现有价值的开源资讯&#xff0c;欢迎您的来稿与推荐&#xff0c;点击上方蓝色字&#xff0c;加入我们吧&#xff01;摘要&#xff1a;较新的BPM版本中&#xff0c;提供了SOAP和REST两种接口&#xff0c…