亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

Python八皇后問題解答過程詳解

系統(tǒng) 1537 0

最近看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)爭(zhēng),皇后們都小心眼,都愛爭(zhēng)風(fēng)吃醋,如果有人和自己在一條線上(水平、垂直、對(duì)角線)就會(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è)皇后和前面的皇后列相同或者在一條對(duì)角線上,則沖突
   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,哈哈。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長(zhǎng)會(huì)非常 感謝您的哦!!!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 香蕉视频免费在线 | 免费a级网站 | 福利精品 | 婷婷热 | 视频在线一区二区三区 | 久久亚洲不卡一区二区 | 精品一区二区视频在线观看 | 99九九99九九九视频精品 | 一级做a爱片特黄在线观看免费看 | 国产精品视频一区国模私拍 | 午夜香蕉视频 | 四虎成人永久影院 | 久久精品30 | 午夜私人影院粉色视频我要 | 久草青青在线 | 精品国产综合区久久久久久 | 一级毛片免费高清视频 | 久久亚洲日本不卡一区二区 | 欧美资源站 | 国产一区二区三区免费观看 | 热综合一本伊人久久精品 | 天天看片天天爽 | 国产高清美女一级a毛片久久 | 成人亚洲天堂 | 日本视频播放免费线上观看 | 亚洲精品成人一区二区aⅴ 亚洲精品成人一区二区www | 视频在线观看一区 | www.深夜| 噜噜噜天天躁狠狠躁夜夜精品 | 国产精品免费_区二区三区观看 | 日日夜夜免费视频 | 国产α片 | 国产亚洲欧美成人久久片 | 一区二区三区不卡在线 | 久久精品免费观看久久 | 久久精品无码一区二区日韩av | 真人特级毛片免费视频 | 四虎最新网址在线观看 | 97超在线视频 | 99久热只有精品视频免费看 | 欧美精品一区二区三区观 |