想了想,沒啥說的,代碼不算難,涉及到的知識(shí)點(diǎn)本文都有說明:
創(chuàng)新互聯(lián)堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:網(wǎng)站設(shè)計(jì)制作、成都網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時(shí)代的魏都網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!#八皇后問題
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)坐標(biāo)能否放皇后
#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(){ //技術(shù)指標(biāo) http://www.fx61.com/faq/muniu/437.html
print("□",end=" ") ??#print()函數(shù)中加一個(gè)“空格(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):
#判斷該位置是否能放當(dāng)前皇后
if can_play(step,i):
#1.設(shè)置現(xiàn)場(chǎng)
board[step][i]=1
#2.開始遞歸
put_queen(step+1)
#3.恢復(fù)現(xiàn)場(chǎng) ??(非常重要!前面的走,后面的要恢復(fù))
board[step][i]=0
if __name__ == "__main__":
print_board(0) ??????#從第0步開始走
print("總共有{}種方法".format(total)) ??#Python的變量輸出格式:{} + format()
range是Python的一個(gè)內(nèi)置函數(shù),其作用是“遍歷其中區(qū)間中的所有值”,遵循“左閉右開”原則
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。