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

python實現的生成隨機迷宮算法核心代碼分享(含游戲完整代碼)

系統 2180 0

完整代碼下載:http://xiazai.jb51.net/201407/tools/python-migong.rar

最近研究了下迷宮的生成算法,然后做了個簡單的在線迷宮游戲。游戲地址和對應的開源項目地址可以通過上面的鏈接找到。開源項目中沒有包含服務端的代碼,因為服務端的代碼實在太簡單了。下面將簡單的介紹下隨機迷宮的生成算法。一旦理解后你會發現這個算法到底有多簡單。

1.將迷宮地圖分成多個房間,每個房間都有四面墻。
2.讓“人”從地圖任意一點A出發,開始在迷宮里游蕩。從A房間的1/2/3/4個方向中的任選一個方向前進。在從A房間走到B房間的過程中,推倒A/B房間之間的墻。
3.如果方向x對面的房間已經走過,則選擇其他方向。如果所有方向的房間都已經走過,則退回上一個房間看是否還有可選道路。
4.走到真正無路可走時,說明已經走過了所有房間,迷宮也生成好了。

下面是該算法的python實現(核心部分)

            
def gen_map(self, max_x=10, max_y=10):
 """ 生成迷宮 """
 self.max_x, self.max_y = max_x, max_y # 設置地圖大小
 self.mmap = [[None for j in range(self.max_y)] for i in range(self.max_x)] # 生成原始地圖
 self.solution = [] # 迷宮解法
 block_stack = [Block(self, 0, 0)] # 從0,0開始生成迷宮(同時將這點作為起點),將起點放到棧里
 while block_stack:
  block = block_stack.pop() #取出當前所在的房間
  next_block = block.get_next_block() # 獲取下一個要去的房間
  if next_block: # 如果成功獲取下一走發,將走過的房間放回到棧里
   block_stack.append(block)
   block_stack.append(next_block)
   if next_block.x == self.max_x - 1 and next_block.y == self.max_y - 1: # 走到終點了,棧里的路徑就是解法
    for o in block_stack:
     self.solution.append((o.x, o.y))
 
def get_next_block_pos(self, direction):
 """ 獲取指定方向的房間號 """
 x = self.x
 y = self.y
 if direction == 0: # Top
  y -= 1
 elif direction == 1: # Right
  x += 1
 if direction == 2: # Bottom
  y += 1
 if direction == 3: # Left
  x -= 1
 return x, y
 
def get_next_block(self):
 """ 獲取下一要去的房間 """
 directions = list(range(4))
 random.shuffle(directions) # 隨機獲取一個要去的方向
 for direction in directions:
  x, y = self.get_next_block_pos(direction)
  if x >= self.mmap.max_x or x < 0 or y >= self.mmap.max_y or y < 0: # 房間號在許可范圍內
   continue
  if self.mmap.mmap[x][y]: # 如果已經走過
   continue
  self.walls[direction] = False
  return Block(self.mmap, x, y, direction)
 return None # 沒找到有可用的房間

          

注: 由于采用該方法生成的迷宮道路的分支數量并不是太多,coffeescript版在生成迷宮的過程中增加了隨機處理,對應算法也稍微復雜一點點。


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

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

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

【本文對您有幫助就好】

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

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 老子影院午夜久久亚洲 | 国产一级成人毛片 | 人人精品久久 | 久久精品国产99国产精品免费看 | 青青操夜夜操 | 九九热精品视频在线播放 | 色婷婷久久久swag精品 | 国产日韩精品视频一区二区三区 | 亚洲精品线在线观看 | 91久久精品国产一区二区 | 色综合久久中文色婷婷 | 在线观看免费情网站大全 | 亚洲欧美在线看 | 一级女人18片毛片免费视频 | 免费网站看v片在线成人国产系列 | 精品久久伦理中文字幕 | 国产午夜精品一区二区三区嫩草 | 理论大片三在线观看 | 久久不射影院 | 欧美 日韩 国产在线 | 国产精品久久久久久免费播放 | 精品图区 | 午夜久久久 | 亚洲精品第一区二区三区 | 成人影院在线免费观看 | 一级毛片免费观看不卡的 | 亚洲狠狠婷婷综合久久久久 | 成人免费视频在线 | 精品视频一区二区三三区四区 | 亚洲国产成人99精品激情在线 | 亚洲欧美一区二区三区在线播放 | 性欧美xo视频在线观看 | 国产自愉怕一区二区三区 | 精品免费国产一区二区三区 | 国产婷婷丁香久久综合 | 一区二区三区www | 91在线免费公开视频 | 三级性生活视频 | 久久国产99 | 奇米第四狠狠777高清秒播 | 全黄冷激性性视频 |