经典问题:八皇后的Python解法-创新互联

想了想,没啥说的,代码不算难,涉及到的知识点本文都有说明:

创新互联坚持“要么做到,要么别承诺”的工作理念,服务领域包括:网站设计制作、成都网站建设、企业官网、英文网站、手机端网站、网站推广等服务,满足客户于互联网时代的魏都网站设计、移动媒体设计的需求,帮助企业找到有效的互联网解决方案。努力成为您成熟可靠的网络建设合作伙伴!

#八皇后问题

board=[

[0,0,0,0,0,0,0,0],

[0,0,0,0,0,0,0,0],

[0,0,0,0,0,0,0,0],

[0,0,0,0,0,0,0,0],

[0,0,0,0,0,0,0,0],

[0,0,0,0,0,0,0,0],

[0,0,0,0,0,0,0,0],

[0,0,0,0,0,0,0,0]

]

total=0;

def can_play(x,y):

#判断(x,y)坐标能否放皇后

#1.判断x行是否有皇后

for i in range(0,y):

if board[x][i]==1:

return False

#2.判断y列是否有皇后

for i in range(0,x):

if board[i][y]==1:

return False

#3.判断左斜是否有皇后

for i in range(0,x):

if x+y-i <= 7 and board[i][x+y-i]==1:

return False

#4.判断右斜是否有皇后

for index,i in enumerate(range(x-1,-1,-1)):

s_y=y-(index+1)

if s_y >= 0:

if board[i][s_y]==1:

return False

return True

def print_board():

for i in range(8):

for j in range(8):

if board[i][j]==0:

function(){ //技术指标 http://www.fx61.com/faq/muniu/437.html

print("□",end=" ")   #print()函数中加一个“空格(end=" ")”,表示不换行

else:

print("■",end=" ")

print()

def put_queen(step):

if step==8:

print_board()

global total

total += 1

print("------------------------")

else:

for i in range(8):

#判断该位置是否能放当前皇后

if can_play(step,i):

#1.设置现场

board[step][i]=1

#2.开始递归

put_queen(step+1)

#3.恢复现场   (非常重要!前面的走,后面的要恢复)

board[step][i]=0

if __name__ == "__main__":

print_board(0)       #从第0步开始走

print("总共有{}种方法".format(total))   #Python的变量输出格式:{} + format()

range是Python的一个内置函数,其作用是“遍历其中区间中的所有值”,遵循“左闭右开”原则

另外有需要云服务器可以了解下创新互联cdcxhl.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


当前题目:经典问题:八皇后的Python解法-创新互联
本文URL:http://scyanting.com/article/cspoes.html