欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

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

系統 1625 0

最近看Python看得都不用tab鍵了,哈哈。今天看了一個經典問題--八皇后問題,說實話,以前學C、C++的時候有這個問題,但是當時不愛學,沒搞會,后來算法課上又碰到,只是學會了思想,應該是學回溯法的時候碰到的。八皇后問題是說要在一個棋盤上放置8個皇后,但是不能發生戰爭,皇后們都小心眼,都愛爭風吃醋,如果有人和自己在一條線上(水平、垂直、對角線)就會引發撕13大戰,所以我們就是要妥當的安排8位娘娘,以保后宮太平。

言歸正傳,首先,我們得想好解決方案怎么表示,這種事首先想到列表,當然規模小的話用元組最好啦,列表都比較熟悉,這次試試元組。每個元組元素指定相應行皇后位置,如state[0] = 3表示第一行皇后在第4列。然后還要知道什么情況不行,就是說找到矛盾,我們定義一個函數:

            
def conflict(state,nextx):
 '定義沖突函數,state為元組,nextx為下一個皇后的水平位置,nexty為下一個皇后的垂直位置'
 nexty = len(state)
 for i in range(nexty):
  if abs(state[i]-nextx) in (0,nexty-i):#若下一個皇后和前面的皇后列相同或者在一條對角線上,則沖突
   return True
 return False
          

最后,我們要解決娘娘們的位置了,先找到一個不沖突的位置,如果這位娘娘是最后一位,那么我們就把娘娘們安排好了,返回該位置到解決方案;如果不是最后一位,也把該位置信息返回到狀態元組(最后的解決方案是含全部位置信息的狀態元組)并傳給后面的皇后,看代碼:

            
def queens(num=8,state=()):
 '八皇后問題,這里num表示規模'
 for pos in range(num):
  if not conflict(state,pos):#位置不沖突
   if len(state) == num - 1:#若是最后一個皇后,則返回該位置
    yield (pos,)
   else:#若不是最后一個皇后,則將該位置返回到state元組并傳給后面的皇后
    for result in queens(num,state + (pos,)):
     yield (pos,) + result
          

哦,最后的最后,我們還得看看解決方案什么樣,定義一個打印函數:

            
def prettyp(solution):
 '打印函數'
 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
#隨機打印一種
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
          

完美達到預期,pass,哈哈。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

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

【本文對您有幫助就好】

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

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 精品国产精品三级精品av网址 | 久久免费在线视频 | 国产精品v欧美精品∨日韩 一级免费黄色免费片 | aaa毛片在线| 97超精品视频在线观看 | 欧美一区视频 | 亚洲国产一区在线 | 夜夜爽天天狠狠九月婷婷 | 婷婷视频网站 | 亚洲欧美中文日韩在线 | 乱码中文字幕人成在线 | 成人免费黄网站 | 久久av一区二区三区 | 黄色网页免费 | 欧美电影免费观看 | 精品在线视频一区 | 亚洲一区欧美日韩 | 日本午夜高清视频 | 97国内精品久久久久久久影视 | 日韩精品 电影一区 亚洲 | 国产福利视频一区二区 | 亚洲激情综合 | 国内精品免费视频 | 精品国产乱码久久久久久丨区2区 | 久在线视频 | avidolzvideo| 美女网站在线观看视频18 | 欧美线人一区二区三区 | 日本毛片爽看免费视频 | 精品久久综合一区二区 | 精品极品三级久久久久 | 亚洲国产精品二区久久 | 国产成人精品免高潮在线观看 | 久草视频电影 | 免费黄网站在线播放 | 欧美国产成人一区二区三区 | 激情丁香六月 | 亚洲色图国产 | 国产一区二区视频在线播放 | 国产一级毛片高清视频完整版 | 婷婷qvod |