亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

<li id="fef64"><dl id="fef64"></dl></li>
<tfoot id="fef64"><pre id="fef64"></pre></tfoot>

主頁 > 知識庫 > 如何用 Python 制作一個迷宮游戲

如何用 Python 制作一個迷宮游戲

熱門標簽:舉辦過冬奧會的城市地圖標注 qt百度地圖標注 電銷機器人系統廠家鄭州 正安縣地圖標注app 遼寧智能外呼系統需要多少錢 400電話申請資格 螳螂科技外呼系統怎么用 地圖地圖標注有嘆號 阿里電話機器人對話

相信大家都玩過迷宮的游戲,對于簡單的迷宮,我們可以一眼就看出通路,但是對于復雜的迷宮,可能要仔細尋找好久,甚至耗費數天,然后可能還要分別從入口和出口兩頭尋找才能找的到通路,甚至也可能找不到通路。

雖然走迷宮問題對于我們人類來講比較復雜,但對于計算機來說卻是很簡單的問題。為什么這樣說呢,因為看似復雜實則是有規可循的。

我們可以這么做,攜帶一根很長的繩子,從入口出發一直走,如果有岔路口就走最左邊的岔口,直到走到死胡同或者找到出路。如果是死胡同則退回上一個岔路口,我們稱之為岔口 A,

這時進入左邊第二個岔口,進入第二個岔口后重復第一個岔口的步驟,直到找到出路或者死胡同退回來。當把該岔路口所有的岔口都走了一遍,還未找到出路就沿著繩子往回走,走到岔口 A 的前一個路口 B,重復上面的步驟。

不知道你有沒有發現,這其實就是一個不斷遞歸的過程,而這正是計算機所擅長的。

上面這種走迷宮的算法就是我們常說的深度優先遍歷算法,與之相對的是廣度優先遍歷算法。有了理論基礎,下面我們就來試著用 程序來實現一個走迷宮的小程序。

生成迷宮

生成迷宮有很多種算法,常用的有遞歸回溯法、遞歸分割法和隨機 Prim 算法,我們今天是用的最后一種算法。

該算法的主要步驟如下:
1、迷宮行和列必須為奇數
2、奇數行和奇數列的交叉點為路,其余點為墻,迷宮四周全是墻
3、選定一個為路的單元格(本例選 [1,1]),然后把它的鄰墻放入列表 wall
4、當列表 wall 里還有墻時:
4.1、從列表里隨機選一面墻,如果這面墻分隔的兩個單元格只有一個單元格被訪問過
4.1.1、那就從列表里移除這面墻,同時把墻打通
4.1.2、將單元格標記為已訪問
4.1.3、將未訪問的單元格的鄰墻加入列表 wall
4.2、如果這面墻兩面的單元格都已經被訪問過,那就從列表里移除這面墻

我們定義一個 Maze 類,用二維數組表示迷宮地圖,其中 1 表示墻壁,0 表示路,然后初始化左上角為入口,右下角為出口,最后定義下方向向量。

class Maze:
 def __init__(self, width, height):
  self.width = width
  self.height = height
  self.map = [[0 if x % 2 == 1 and y % 2 == 1 else 1 for x in range(width)] for y in range(height)]
  self.map[1][0] = 0 # 入口
  self.map[height - 2][width - 1] = 0 # 出口
  self.visited = []
  # right up left down
  self.dx = [1, 0, -1, 0]
  self.dy = [0, -1, 0, 1]

接下來就是生成迷宮的主函數了。

def generate(self):
 start = [1, 1]
 self.visited.append(start)
 wall_list = self.get_neighbor_wall(start)
 while wall_list:
  wall_position = random.choice(wall_list)
  neighbor_road = self.get_neighbor_road(wall_position)
  wall_list.remove(wall_position)
  self.deal_with_not_visited(neighbor_road[0], wall_position, wall_list)
  self.deal_with_not_visited(neighbor_road[1], wall_position, wall_list)

該函數里面有兩個主要函數 get_neighbor_road(point) 和 deal_with_not_visited(),前者會獲得傳入坐標點 point 的鄰路節點,返回值是一個二維數組,后者 deal_with_not_visited() 函數處理步驟 4.1 的邏輯。

由于 Prim 隨機算法是隨機的從列表中的所有的單元格進行隨機選擇,新加入的單元格和舊加入的單元格被選中的概率是一樣的,因此其分支較多,生成的迷宮較復雜,難度較大,當然看起來也更自然些。生成的迷宮。
[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1]
[0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1]
[1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1]
[1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1]
[1, 1, 1, 0, 1, 0, 1, 0, 1, 0, 1]
[1, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1]
[1, 0, 1, 0, 1, 0, 1, 1, 1, 1, 1]
[1, 0, 1, 0, 1, 0, 0, 0, 0, 0, 1]
[1, 0, 1, 0, 1, 1, 1, 0, 1, 0, 1]
[1, 0, 1, 0, 1, 0, 0, 0, 1, 0, 0]
[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1]

走出迷宮

得到了迷宮的地圖,接下來就按照我們文首的思路來走迷宮即可。主要函數邏輯如下:

def dfs(self, x, y, path, visited=[]):
 # outOfIndex
 if self.is_out_of_index(x, y):
  return False

 # visited or is wall
 if [x, y] in visited or self.get_value([x, y]) == 1:
  return False

 visited.append([x, y])
 path.append([x, y])

 # end...
 if x == self.width - 2 and y == self.height - 2:
  return True

 # recursive
 for i in range(4):
  if 0  x + self.dx[i]  self.width - 1 and 0  y + self.dy[i]  self.height - 1 and \

    self.get_value([x + self.dx[i], y + self.dy[i]]) == 0:
   if self.dfs(x + self.dx[i], y + self.dy[i], path, visited):
    return True
   elif not self.is_out_of_index(x, y) and path[-1] != [x, y]:
    path.append([x, y])

很明顯,這就是一個典型的遞歸程序。當該節點坐標越界、該節點被訪問過或者該節點是墻壁的時候,直接返回,因為該節點肯定不是我們要找的路徑的一部分,否則就將該節點加入被訪問過的節點和路徑的集合中。

然后如果該節點是出口則表示程序執行結束,找到了通路。不然就遍歷四個方向向量,將節點的鄰路傳入函數 dfs 繼續以上步驟,直到找到出路或者程序所有節點都遍歷完成。

來看看我們 dfs 得出的路徑結果:

[[0, 1], [1, 1], [2, 1], [3, 1], [4, 1], [5, 1], [6, 1], [7, 1], [8, 1], [9, 1], [9, 1], [8, 1], [7, 1], [6, 1], [5, 1], [5, 2], [5, 3], [6, 3], [7, 3], [8, 3], [9, 3], [9, 4], [9, 5], [9, 5], [9, 4], [9, 3], [8, 3], [7, 3], [7, 4], [7, 5], [7, 5], [7, 4], [7, 3], [6, 3], [5, 3], [4, 3], [3, 3], [2, 3], [1, 3], [1, 3], [2, 3], [3, 3], [3, 4], [3, 5], [2, 5], [1, 5], [1, 6], [1, 7], [1, 8], [1, 9], [1, 9], [1, 8], [1, 7], [1, 6], [1, 5], [2, 5], [3, 5], [3, 6], [3, 7], [3, 8], [3, 9], [3, 9], [3, 8], [3, 7], [3, 6], [3, 5], [3, 4], [3, 3], [4, 3], [5, 3], [5, 4], [5, 5], [5, 6], [5, 7], [6, 7], [7, 7], [8, 7], [9, 7], [9, 8], [9, 9], [10, 9]]

可視化

有了迷宮地圖和通路路徑,剩下的工作就是將這些坐標點渲染出來。今天我們用的可視化庫是 pyxel,這是一個用來寫像素級游戲的 Python 庫,

當然使用前需要先安裝下這個庫。

Win 用戶直接用 pip install -U pyxel命令安裝即可。

Mac 用戶使用以下命令安裝:

brew install python3 gcc sdl2 sdl2_image gifsicle
pip3 install -U pyxel

先來看個簡單的 Demo。

import pyxel

class App:
 def __init__(self):
  pyxel.init(160, 120)
  self.x = 0
  pyxel.run(self.update, self.draw)

 def update(self):
  self.x = (self.x + 1) % pyxel.width

 def draw(self):
  pyxel.cls(0)
  pyxel.rect(self.x, 0, 8, 8, 9)

App()

類 App 的執行邏輯就是不斷的調用 update 函數和 draw 函數,因此可以在 update 函數中更新物體的坐標,然后在 draw 函數中將圖像畫到屏幕即可。

如此我們就先把迷宮畫出來,然后在渲染 dfs 遍歷動畫。

width, height = 37, 21
my_maze = Maze(width, height)
my_maze.generate()

class App:
 def __init__(self):
  pyxel.init(width * pixel, height * pixel)
  pyxel.run(self.update, self.draw)

 def update(self):
  if pyxel.btn(pyxel.KEY_Q):
   pyxel.quit()

  if pyxel.btn(pyxel.KEY_S):
   self.death = False

 def draw(self):
  # draw maze
  for x in range(height):
   for y in range(width):
    color = road_color if my_maze.map[x][y] is 0 else wall_color
    pyxel.rect(y * pixel, x * pixel, pixel, pixel, color)
  pyxel.rect(0, pixel, pixel, pixel, start_point_color)
  pyxel.rect((width - 1) * pixel, (height - 2) * pixel, pixel, pixel, end_point_color)

App()

看起來還可以,這里的寬和高我分別用了 37 和 21 個像素格來生成,所以生成的迷宮不是很復雜,如果像素點很多的話就會錯綜復雜了。

接下里來我們就需要修改 update 函數和 draw 函數來渲染路徑了。為了方便操作,我們在 init 函數中新增幾個屬性。

self.index = 0
self.route = [] # 用于記錄待渲染的路徑
self.step = 1 # 步長,數值越小速度越快,1:每次一格;10:每次 1/10 格
self.color = start_point_color
self.bfs_route = my_maze.bfs_route()

其中 index 和 step 是用來控制渲染速度的,在 draw 函數中 index 每次自增 1,然后再對 step 求余數得到當前的真實下標 real_index,簡言之就是 index 每增加 step,real_index 才會加一,渲染路徑向前走一步。

def draw(self):
 # draw maze
 for x in range(height):
  for y in range(width):
   color = road_color if my_maze.map[x][y] is 0 else wall_color
   pyxel.rect(y * pixel, x * pixel, pixel, pixel, color)
 pyxel.rect(0, pixel, pixel, pixel, start_point_color)
 pyxel.rect((width - 1) * pixel, (height - 2) * pixel, pixel, pixel, end_point_color)

 if self.index > 0:
  # draw route
  offset = pixel / 2
  for i in range(len(self.route) - 1):
   curr = self.route[i]
   next = self.route[i + 1]
   self.color = backtrack_color if curr in self.route[:i] and next in self.route[:i] else route_color
   pyxel.line(curr[0] + offset, (curr[1] + offset), next[0] + offset, next[1] + offset, self.color)
  pyxel.circ(self.route[-1][0] + 2, self.route[-1][1] + 2, 1, head_color)
def update(self):
 if pyxel.btn(pyxel.KEY_Q):
  pyxel.quit()

 if pyxel.btn(pyxel.KEY_S):
  self.death = False

 if not self.death:
  self.check_death()
  self.update_route()

def check_death(self):
 if self.dfs_model and len(self.route) == len(self.dfs_route) - 1:
  self.death = True
 elif not self.dfs_model and len(self.route) == len(self.bfs_route) - 1:
  self.death = True

def update_route(self):
 index = int(self.index / self.step)
 self.index += 1
 if index == len(self.route): # move
  if self.dfs_model:
   self.route.append([pixel * self.dfs_route[index][0], pixel * self.dfs_route[index][1]])
  else:
   self.route.append([pixel * self.bfs_route[index][0], pixel * self.bfs_route[index][1]])

App()

至此,我們完整的從迷宮生成,到尋找路徑,再到路徑可視化已全部實現。直接調用主函數 App() 然后按 S 鍵盤開啟游戲

總結

今天我們用深度優先算法實現了迷宮的遍歷,對于新手來說,遞歸這思路可能比較難理解,但這才是符合計算機思維的,隨著經驗的加深會理解越來越深刻的。

其次我們用 pyxel 庫來實現路徑可視化,難點在于坐標的計算更新,細節比較多且繁瑣,當然讀者也可以用其他庫或者直接用網頁來實現也可以。

游戲源碼:
https://github.com/JustDoPython/python-examples/blob/master/doudou/2020-06-12-maze/maze.py
快來一試身手吧。

以上就是如何用 Python 制作一個迷宮游戲的詳細內容,更多關于python 制作迷宮游戲的資料請關注腳本之家其它相關文章!

您可能感興趣的文章:
  • Python 實現遞歸法解決迷宮問題的示例代碼
  • Python迷宮生成和迷宮破解算法實例
  • 10分鐘教你用python動畫演示深度優先算法搜尋逃出迷宮的路徑
  • Python解決走迷宮問題算法示例
  • 一道python走迷宮算法題
  • Python深度優先算法生成迷宮
  • Python使用Tkinter實現機器人走迷宮
  • Python基于分水嶺算法解決走迷宮游戲示例
  • Python使用回溯法子集樹模板解決迷宮問題示例
  • Python基于遞歸算法實現的走迷宮問題
  • 用Python代碼來解圖片迷宮的方法整理
  • python實現的生成隨機迷宮算法核心代碼分享(含游戲完整代碼)
  • 教你怎么用Python實現多路徑迷宮

標簽:合肥 昭通 阜新 信陽 淘寶好評回訪 隨州 濟源 興安盟

巨人網絡通訊聲明:本文標題《如何用 Python 制作一個迷宮游戲》,本文關鍵詞  如,何用,Python,制作,一個,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《如何用 Python 制作一個迷宮游戲》相關的同類信息!
  • 本頁收集關于如何用 Python 制作一個迷宮游戲的相關信息資訊供網民參考!
  • 推薦文章
    亚洲精品久久久中文字| 超级乱淫黄漫画免费| 九九久久国产精品| 久久国产精品自由自在| 免费国产在线观看| 亚洲天堂免费| 99色视频在线观看| 精品久久久久久中文字幕2017| 久久福利影视| 日韩一级黄色| 久久久成人网| 亚洲精品影院久久久久久| 国产伦精品一区三区视频| 国产亚洲精品aaa大片| 四虎久久精品国产| 你懂的日韩| 国产精品免费久久| 韩国三级视频网站| 亚洲天堂免费| 欧美a级成人淫片免费看| 国产伦久视频免费观看 视频| 欧美大片一区| 国产网站免费视频| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 韩国三级香港三级日本三级la| 欧美激情一区二区三区在线| 沈樵在线观看福利| 成人免费高清视频| 国产网站麻豆精品视频| 日本在线www| 久久久久久久男人的天堂| 国产a视频| 国产高清视频免费| 日韩在线观看视频黄| 精品国产一区二区三区久| 99久久精品国产高清一区二区 | 日韩avdvd| 日韩一级黄色| 美国一区二区三区| 青青青草影院| 97视频免费在线| 四虎久久精品国产| 日韩字幕在线| 国产麻豆精品免费视频| 99久久精品国产国产毛片| 国产激情一区二区三区| 久久精品免视看国产明星| 韩国三级视频在线观看| 尤物视频网站在线| 午夜在线亚洲| 黄视频网站免费看| 久久精品大片| 成人免费观看男女羞羞视频| 成人在激情在线视频| 日本特黄特色aaa大片免费| 日本乱中文字幕系列| 夜夜操网| 精品国产香蕉在线播出| 色综合久久天天综线观看| 亚洲 男人 天堂| 一级片免费在线观看视频| 日韩男人天堂| 国产原创视频在线| 国产成人精品综合在线| 黄色短视屏| 欧美1卡一卡二卡三新区| 国产原创视频在线| 91麻豆国产| 久久国产一久久高清| 国产91素人搭讪系列天堂| 午夜久久网| 日韩中文字幕一区| 人人干人人插| 欧美另类videosbestsex高清| 欧美另类videosbestsex视频| 亚洲天堂在线播放| 成人在激情在线视频| 日本伦理片网站| 欧美一级视频免费| 青青青草影院| 国产高清视频免费| 亚洲爆爽| 久久福利影视| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 九九精品在线播放| 亚洲爆爽| 亚久久伊人精品青青草原2020| 一本高清在线| 午夜激情视频在线播放| 黄视频网站免费看| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 国产精品免费久久| 成人a大片高清在线观看| 黄色免费网站在线| 美国一区二区三区| 一级女性大黄生活片免费| 中文字幕97| 国产伦久视频免费观看 视频| 日韩在线观看视频黄| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 久久国产影院| 日日日夜夜操| 香蕉视频亚洲一级| 国产精品1024永久免费视频| 日韩在线观看视频黄| 日韩avdvd| 日日夜夜婷婷| 亚洲天堂免费| 毛片高清| 国产视频一区在线| 日韩中文字幕在线播放| 一本高清在线| 午夜在线影院| 欧美一区二区三区在线观看| 亚洲天堂免费| 亚洲第一页乱| 成人免费观看网欧美片| 二级特黄绝大片免费视频大片| 日韩中文字幕在线播放| 一a一级片| 亚洲第一页乱| 国产欧美精品| 欧美国产日韩在线| 国产一区免费观看| 黄色免费网站在线| 天天做人人爱夜夜爽2020| 一级毛片视频播放| 超级乱淫黄漫画免费| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 精品国产一区二区三区久| 国产网站麻豆精品视频| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 成人在激情在线视频| 国产一区二区精品久久91| 毛片高清| 国产国语对白一级毛片| 日韩中文字幕在线播放| 国产欧美精品| 日韩中文字幕在线亚洲一区| 国产伦久视频免费观看 视频| 欧美激情一区二区三区中文字幕| 国产精品免费久久| 精品视频在线观看视频免费视频| 久久99这里只有精品国产| 国产精品免费久久| 成人免费观看男女羞羞视频| 国产美女在线观看| 亚洲天堂免费| 国产精品123| 成人a大片高清在线观看| 毛片高清| 日本在线www| 精品久久久久久中文字幕2017| 亚洲天堂免费| 国产视频一区在线| 欧美激情一区二区三区视频| 午夜在线影院| 日本免费区| 成人高清视频在线观看| 999精品在线| 国产一区二区精品久久91| a级黄色毛片免费播放视频| 91麻豆tv| 欧美一区二区三区在线观看| 国产成a人片在线观看视频| 91麻豆国产级在线| 国产伦理精品| 亚洲wwwwww| 午夜久久网| 国产精品123| 99久久精品国产片| 国产伦精品一区三区视频| 国产高清在线精品一区二区| 亚洲wwwwww| 亚久久伊人精品青青草原2020| 一级毛片视频在线观看| 精品国产一区二区三区免费| 欧美大片一区| 99热精品在线| 国产91精品一区| 日韩欧美一二三区| 欧美a免费| 中文字幕97| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 青草国产在线观看| 精品国产一区二区三区久| 久草免费在线色站| 日韩在线观看视频黄| 国产精品免费久久| 成人a级高清视频在线观看| 香蕉视频亚洲一级| 999久久狠狠免费精品| 精品视频在线观看视频免费视频| 国产麻豆精品| 91麻豆精品国产自产在线| 色综合久久天天综线观看| 国产麻豆精品高清在线播放| 亚洲爆爽| 超级乱淫黄漫画免费| 午夜精品国产自在现线拍|