Python八皇后問題解答過程詳解
最近看Python看得都不用tab鍵了,哈哈。今天看了一個(gè)經(jīng)典問題--八皇后問題,說實(shí)話,以前學(xué)C、C++的時(shí)候有這個(gè)問題,但是當(dāng)時(shí)不愛學(xué),沒搞會(huì),后來算法課上又碰到,只是學(xué)會(huì)了思想,應(yīng)該是學(xué)回溯法的時(shí)候碰到的。八皇后問題是說要在一個(gè)棋盤上放置8個(gè)皇后,但是不能發(fā)生戰(zhàn)爭,皇后們都小心眼,都愛爭風(fēng)吃醋,如果有人和自己在一條線上(水平、垂直、對角線)就會(huì)引發(fā)撕13大戰(zhàn),所以我們就是要妥當(dāng)?shù)陌才?位娘娘,以保后宮太平。
言歸正傳,首先,我們得想好解決方案怎么表示,這種事首先想到列表,當(dāng)然規(guī)模小的話用元組最好啦,列表都比較熟悉,這次試試元組。每個(gè)元組元素指定相應(yīng)行皇后位置,如state[0] = 3表示第一行皇后在第4列。然后還要知道什么情況不行,就是說找到矛盾,我們定義一個(gè)函數(shù):
def conflict(state,nextx): '定義沖突函數(shù),state為元組,nextx為下一個(gè)皇后的水平位置,nexty為下一個(gè)皇后的垂直位置' nexty = len(state) for i in range(nexty): if abs(state[i]-nextx) in (0,nexty-i):#若下一個(gè)皇后和前面的皇后列相同或者在一條對角線上,則沖突 return True return False
最后,我們要解決娘娘們的位置了,先找到一個(gè)不沖突的位置,如果這位娘娘是最后一位,那么我們就把娘娘們安排好了,返回該位置到解決方案;如果不是最后一位,也把該位置信息返回到狀態(tài)元組(最后的解決方案是含全部位置信息的狀態(tài)元組)并傳給后面的皇后,看代碼:
def queens(num=8,state=()):
'八皇后問題,這里num表示規(guī)模'
for pos in range(num):
if not conflict(state,pos):#位置不沖突
if len(state) == num - 1:#若是最后一個(gè)皇后,則返回該位置
yield (pos,)
else:#若不是最后一個(gè)皇后,則將該位置返回到state元組并傳給后面的皇后
for result in queens(num,state + (pos,)):
yield (pos,) + result
哦,最后的最后,我們還得看看解決方案什么樣,定義一個(gè)打印函數(shù):
def prettyp(solution): '打印函數(shù)' def line(pos,length = len(solution)): '打印一行,皇后位置用X填充,其余用0填充' return 'O'*(pos)+'X'+'O'*(length-pos-1) for pos in solution: print(line(pos))
讓我們看看效果:
import random #隨機(jī)打印一種 prettyp(random.choice(list(queens(8)))) D:\Python34\python.exe D:/Python34/hanshu.py OOOOOOOX OOXOOOOO XOOOOOOO OOOOOXOO OXOOOOOO OOOOXOOO OOOOOOXO OOOXOOOO Process finished with exit code 0
完美達(dá)到預(yù)期,pass,哈哈。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Python使用numpy產(chǎn)生正態(tài)分布隨機(jī)數(shù)的向量或矩陣操作示例
這篇文章主要介紹了Python使用numpy產(chǎn)生正態(tài)分布隨機(jī)數(shù)的向量或矩陣操作,簡單描述了正態(tài)分布的概念并結(jié)合實(shí)例形式分析了Python使用numpy模塊結(jié)合matplotlib繪制正態(tài)分布曲線圖相關(guān)操作技巧,需要的朋友可以參考下2018-08-08
Python檢測數(shù)據(jù)類型的方法總結(jié)
在本篇文章里小編給大家整理了關(guān)于Python檢測數(shù)據(jù)類型的方法和相關(guān)實(shí)例代碼,需要的朋友們跟著學(xué)習(xí)下。2019-05-05
Python使用pyinstaller打包成.exe文件執(zhí)行后閃退的圖文解決辦法
這篇文章主要給大家介紹了關(guān)于Python使用pyinstaller打包成.exe文件執(zhí)行后閃退的圖文解決辦法,閃退問題通常是由于程序運(yùn)行過程中出現(xiàn)了未處理的異常或錯(cuò)誤,導(dǎo)致程序崩潰,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下2023-12-12
python數(shù)據(jù)類型判斷type與isinstance的區(qū)別實(shí)例解析
這篇文章主要介紹了python數(shù)據(jù)類型判斷type與isinstance的區(qū)別實(shí)例解析,具有一定參考價(jià)值,需要的朋友可以了解下。2017-10-10
Python簡繁體轉(zhuǎn)換的簡單實(shí)現(xiàn)步驟
工作中需要將繁體中文轉(zhuǎn)換成簡體中文上網(wǎng)找了些資料,下面這篇文章主要給大家介紹了關(guān)于Python實(shí)現(xiàn)簡繁體轉(zhuǎn)換的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-06-06
Python時(shí)間和日期庫的實(shí)現(xiàn)
這篇文章主要介紹了Python時(shí)間和日期庫的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03

