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

來源:互聯網
上載者:User
完整代碼下載:http://xiazai.bitsCN.com/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版在產生迷宮的過程中增加了隨機處理,對應演算法也稍微複雜一點點。

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.