国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院

首頁 > 編程 > Python > 正文

python實現推箱子游戲

2020-02-15 23:43:54
字體:
來源:轉載
供稿:網友

本文實例為大家分享了python實現推箱子游戲的具體代碼,供大家參考,具體內容如下

題目描述:

最短路徑為:

uurrDDDDuuuulldRurDDDrddLLrruLuuulldRurDDDrdL

u表示向上,d表示向下,l表示向左,r表示向右。

大寫表示人推著箱子一起動,小寫表示人自己走。

代碼用BFS實現。狀態要分推著箱子一起走和人單獨走,這兩種狀態轉移是不同的。

由于代碼中注釋較詳細,這里不過多解釋。

代碼:

# -*- coding: utf-8 -*-# @Time  : 2017/8/10 上午9:42# @Author : Qi MO# @File  : BFS.py# @Software: PyCharm Community Edition level_file_path = '../數據/level_file.txt' class GameShortest:  def __init__(self,line, col=10):    """    給一個圖,長度為100的字符串表示。    0空地 1墻 2箱子起始位置 3箱子終點位置 4人的起始位置    :param line: 地圖,用字符串表示。如代碼最后的每一行表示每一關的地圖。    :param col: 地圖的長寬,由于設定為10*10,默認為10    """     self.line = line    # sta和en 表示開始的狀態,結束的狀態    # sta只有2,4,0 2表示箱子開始位置,4表示人的位置,0表示其他。    # en只有1,3,0 1表示墻,3表示箱子結束位置,0表示其他。    # 現在只需要把sta狀態中的2位置移動到en的3的位置即滿足條件    self.sta = ''    self.en = ''    self.col = col    # px, py表示4的位置    self.px,self.py = -1,-1    # paths記錄最短路徑(可能有多條)    self.paths = []    # len記錄最短路徑長度 如    self.len = -1     self.pre()    self.BFS()    print(self.paths)   def pre(self):    """    1.獲得sta開始狀態和en結束狀態    2.獲得人的起始位置px,py    代碼最后的第一關的地圖可視化為    1111111111    1111111111    1110001111    1110221111    1114201111    1111100111    1111300111    1113300111    1111111111    1111111111    :return:    """    mp = []    for pos in range(0, 100, 10):      mp.append(self.line[pos:pos + 10])    # print(self.line)    # for x in mp:    #   print(x)     for pos, enum in enumerate(self.line):      cx, cy = pos // 10, pos % 10      if enum == '4':        self.px, self.py = cx, cy    # 現在只需要把sta開始的狀態中的2位置移動到en的3的位置即滿足條件    staDic = {'0': '0', '1': '0', '2': '2', '3': '0', '4': '4'}    enDic = {'0': '0', '1': '1', '2': '0', '3': '3', '4': '0'}    for x in self.line:      self.sta += staDic[x]      self.en += enDic[x]    # print(self.sta)    # print(self.en)   def is_ok(self,sta):    """    sta狀態中的2位置移動到en的3的位置。    :param sta:    :return:    """    for s,e in zip(sta,self.en):      if e == '3' and s != '2':        return False    return True   def BFS(self):    """    BFS獲得最短路徑保存到paths中    :return:    """    # 4個方向,小寫代表只是人移動,大寫表示人推著箱子一起移動    dirs = [[-1,0,'u','U'],[1,0,'d','D'],[0,1,'r','R'],[0,-1,'l','L']]    # 把開始的狀態進入隊列(list模擬),狀態包括字符串表示的當前狀態、當前的路徑、當前人的位置    states = [[self.sta,'',self.px,self.py]]    # 訪問數組(dict模擬),訪問過的狀態(字符串)不再訪問    visi = {}    visi[self.sta] = 1     s_len = 1000    while len(states)>0:      sta, path, px, py = states[0]      # 4狀態的位置      ppos = px*self.col + py      states = states[1:]      if len(path)>s_len:        break      # 保存最短路徑到paths中      if self.is_ok(sta):        if self.len == -1 or len(path) == self.len:          self.paths.append(path)          self.len = len(path)        continue       for dir in dirs:        cx, cy = px + dir[0], py + dir[1]        # 4挨著的狀態的位置        pos = cx*self.col+cy        nx, ny = px + 2*dir[0], py + 2*dir[1]        # 4挨著挨著的狀態的位置        npos = nx*self.col+ny        if not (nx>=0 and nx<self.col and ny>=0 and ny<self.col):          continue        # python中字符串不可更改,于是把字符串變成list更改狀態后再轉換為字符串        if sta[pos] == '2' and sta[npos] == '0' and self.en[npos] != '1':        # 人和箱子一起推動,sta中連著的狀態為4 2 0,en中第三個不能為1。推完之后sta變為0 4 2          digits = [int(x) for x in sta]          digits[ppos],digits[pos],digits[npos] = 0,4,2          new_sta = ''.join(str(x) for x in digits)          if new_sta not in visi:            visi[new_sta] = 1            states.append([new_sta, path+dir[3], cx, cy])        elif sta[pos] == '0' and self.en[pos] !='1':        # 人動箱子不動,sta中連著的狀態為4 0,en中第二個不能為1。          digits = [int(x) for x in sta]          digits[ppos], digits[pos] = 0, 4          new_sta = ''.join(str(x) for x in digits)          if new_sta not in visi:            visi[new_sta] = 1            states.append([new_sta, path + dir[2], cx, cy]) if __name__ == '__main__':  f = open(level_file_path, encoding='utf-8')  cnt = 0  while(1):    line = f.readline()    line = line.strip('/n')    if len(line)==0 :      break    gs = GameShortest(line) """level_file.txt中內容:11111111111111111111111000111111102211111114201111111110011111113001111113300111111111111111111111111111111111104000000110000200111001101011100100101110010010111001011001110030000111111111111111111111111111111111111111111111111111111031111114002000111023002011111131111111111111111111111111111111111111111111111111111111111000111111102211111110133111111023011111100401111111111111111111111111111111111111111111111111111111111111111100000111112111001113030020111400100011111111111111111111111111111111111111111111111111111111111111111001111110000001111100122011114030031111111111111111111111111111111111111111111100400011100000001110011100111100110011110201301111000020111113111111111111111111111111111111111111111111111111111111111100111111100320001110131210111000000411111111111111111111111111111111111111111111111111111111111111110000011110011101111000202011100013341111111111111111111111111111111111111111111111111111111001111111100041111111010111113121001111320010111130002011111111111111111111111111111111111111111111000001111131103111110402011111001201111100100111111111111111111111111111111111111111111111111111111110000111111311201111023400111100100011110000111111111111111111111111111111111111111111111111111111111110011111102041111110200111113001011111300001111111111111111111111111111111111111111111111111111111143001111100000111110010211111001203111111101011111110001111111111111111111111111111111111111111111111111111110000111111020211111103342011111113001111111111111111111111111111111111111111111111111111111100011111002301111140323011111101201111110001111111111111111111111111111111111111111111111111111111110031111102010111110020011111031401111100001111111111111111111111111111111111111111111111111111111111110411111311001111033020111102120011110000111111111111111111111111111111111111111111111111111111110001111111003301111100112111111001001111120004111110011111111111111111111111111111111111111111111111100001111103032111110024001111111010111111100011111111111111111111111111111111每一關的最短路徑:['uurrDDDDuuuulldRurDDDrddLLrruLuuulldRurDDDrdL']['drrRRurDDDDDrdLLL']['rrdrUrrrdLLulDullldR']['lluRRdrUllluuurrDDuulldRurD']['urrrrdrruulullllDurrrrdrddllullLrrrdrruLLL']['uurrrrDulllddrrRuulDrdL']['drrdddrdLLLuLDlUUUluRRRRurDDD']['uullLLddrrUdlllluuRurDrRddrruuLLL']['lUlLLdlluururrrrDDrdLullldlluRRRRllluurrrrdD']['ddrddLLulLdlUrrrdrruuluulldDuurrddrddllLLrruLL']['luurrrdrdLLLrrrddlUruuulllldDrddlUUrrRdrU']['ddlluluRuurrrDrddlluLrdrruLLddlluU']['dddlluluuRDrruulDrdLLulDrDLurrrddlLL']['drrdDrrddllUUUUruLdrDldR', 'drrdDrrddllUUUUrDldRuuuL']['drruLLLuulldRurDurDD']['urRdddrrUULLulldRururrD']['uLrddlluluuRDrrruullDldRRdrUU']['dddlUllllddrUUddrrUruLLrrruulDrdLL']['llldlUUUluurDrrrDDrdLLLulUluRRlddrddlUUUluR']['ulldRurDrrddllUUluurrDLLdrddrruuLrddlluU']"""            
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院
www在线播放| 伊人中文在线| 久久综合第一页| 亚洲成年人视频| 在线午夜视频| 欧美视频免费一区二区三区| 蜜桃视频网站在线| 九九热精品在线视频| 国产小视频福利在线| 国产传媒在线播放| 中文字幕av高清| 在线一区观看| 国产九色视频| 国产爆初菊在线观看免费视频网站| 国产精品不卡一区二区三区在线观看| 99热免费观看| 日本中文字幕视频| 91中文字幕| 国产嫩草在线视频| av在线不卡播放| 国产视频第一区| 任你操视频在线观看| 国产精品久久久久久久牛牛| www.九九热.com| 精品一区二区在线欧美| 国产伦精品一区二区三区高清版禁| 国产午夜视频| 天天插天天色| 精品欧美日韩一区二区| 欧美性猛交p30| 高清av在线| 精品国产丝袜高跟鞋| 丁香在线视频| av亚洲在线| 国产aa视频| 国产婷婷视频在线| 国产在线高清理伦片a| 亚洲视频手机在线观看| 国产高清av| 国产网站在线免费观看| 中文字幕色视频| 欧美xxxx黑人又粗又长| 国产欧美在线观看视频| 中文字幕在线第一页| 国产中文第一页| 免费看黄视频网站| 激情综合丁香| 国产美女极品在线| 久久精品国产麻豆| 精品孕妇一区二区三区| 欧美日韩在线精品成人综合网| 日本不卡视频一区二区| 麻豆精品视频入口| 国产鲁鲁视频在线观看特色| 国产原创精品视频| 国产主播福利在线| 国产精品自产拍在线观看2019| 午夜在线视频播放| 国产在线中文字幕| 国产天堂资源| 亚洲一本大道| 国产在线一区二区视频| 国产日韩精品在线看| 在线播放黄色网址| 国产蜜臀av在线播放| 国产精品777一区二区| 在线一区观看| 开心婷婷激情五月| 国产精品黄页网站在线播放免费| 国产一级免费| av大片在线播放| 久久久久久五月天久久久久久久久| 狠狠操视频网| 四虎影院成人| 在线免费观看你懂的| 国产盗摄精品一区二区酒店| 国产亚洲精品久久久网站好莱| 国产经典av| 日本卡一卡2卡3卡4精品卡网站| 国产乱精品一区二区三区| 国产xxx在线| 免费在线看v| 在线观看中文字幕的网站| 最新av免费看| 麻豆精品传媒视频观看| 中文字幕av高清在线观看| 国产主播福利在线| 精品久久亚洲一级α| 最新超碰在线| 国产在线播放av| www在线免费观看视频| 97在线免费| 国产成人高清精品| 国产小视频免费在线网址| 九九色在线观看| 免费高清视频日韩| 秋霞av在线| 99re在线视频播放| 国产爆初菊在线观看免费视频网站 | 992tv在线观看在线播放| 国产你懂的在线观看| 免费a级毛片在线播放| 人人九九精品| www在线观看播放免费视频日本| 依依成人在线| 日韩a视频在线观看| 四虎a级欧美在线观看| 四虎成人精品在永久在线观看| 亚洲精品乱码电影在线观看| 性国产高清在线观看| av丝袜在线| eeuss在线观看| 青青九九免费视频在线| 高清欧美精品xxxxx在线看| 久久久久久77777| 九九热视频免费在线观看| 天堂中文在线视频| 午夜不卡视频| 国产精品合集一区二区| 一本大道香蕉久久| 国产在线高潮| 精品麻豆一区二区三区 | 99热播在线观看| 欧美色欧美亚洲另类二区精品| 麻豆国产在线播放| 国产精品综合久久久久| 国产亚洲精品久久久久久青梅| 国产黄色免费看| 亚洲天堂电影在线观看| 二人午夜免费观看在线视频| 国产激情视频一区二区三区| 国产偷激情在线| 天堂网中文在线| 国产高清在线看| 九九免费视频| 在线观看免费观看在线91| 国产一二三区在线视频| 精品免费视频一卡2卡三卡4卡不卡| 欧美成人亚洲高清在线观看| 麻豆福利在线观看| 91美女主播在线视频| 非洲黑人最猛性xxxx交| 精品国产一区二区三区不卡在线 | 欧美日韩视频精品二区| 国产一级视频| 欧美婷婷久久五月精品三区| 国产黄大片在线观看画质优化| 国产中文伊人| 久热免费视频| 日韩a视频在线观看| 一级二级三级在线观看| 18av在线播放| 国产素人视频在线观看| av在线二区| 亚洲91av| 青青艹在线视频| jizz性欧美| 日本视频三区| 四虎www视频| 天天噜天天色| 天天操夜夜添| 日本h片在线观看| 欧美aaa一级片| jlzzjlzz欧美| 欧美韩日国产| 国产毛片在线看| 超碰在线人人| 国产一级片网站| 91caoporn在线| 国产一级黄色| 91三级在线| 日本精品一区二区三区在线播放| 四虎国产精品永久在线| www.综合网.com| 九九在线视频| 国产三级视频在线播放线观看| 91麻豆福利| 热99在线观看| 国产在线超碰| 国产xxxx做受性欧美88| 一本久久精品| 国产在线观看91| 精品女厕厕露p撒尿| 亚洲欧美一区二区三区在线播放| www.jizz在线观看| 国产麻豆精品入口在线观看| 国产丝袜自拍| 亚洲欧美精品中文第三| 国产乱子伦三级在线播放| 国产激情视频在线| www.九九热.com| 国产小视频在线播放| 日本动漫理论片在线观看网站| 国产一级性片| 啪啪免费视频一区| 91黄色在线| 最新亚洲精品国自产在线观看| 在线免费看黄av| 成年网站免费入口在线观看| 精品久久亚洲一级α|