国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

Python深度優先算法生成迷宮

2020-02-22 22:56:01
字體:
來源:轉載
供稿:網友

本文實例為大家分享了Python深度優先算法生成迷宮,供大家參考,具體內容如下

import random  #warning: x and y confusing  sx = 10 sy = 10 dfs = [[0 for col in range(sx)] for row in range(sy)] maze = [[' ' for col in range(2*sx+1)] for row in range(2*sy+1)] #1:up 2:down 3:left 4:right operation = {1:(0,-1),2:(0,1),3:(-1,0),4:(1,0)} direction = [1, 2, 3, 4] stack = []  for i in range(2*sx+1):  if i%2 == 0:   for j in range(2*sx+1):    maze[i][j] = '#' for i in range(2*sy+1):  if i%2 == 0:   for j in range(2*sy+1):    maze[j][i] = '#'  def show(graph):  for i in graph:   for j in i:    print j,   print  def showRouter(stack):  RGragh = [[0 for col in range(sx)] for row in range(sy)]  for (x, y) in stack:   RGragh[y][x] = 1  show(RGragh)  print  def generateMaze(start):  x, y = start  dfs[y][x] = 1  random.shuffle(direction)  for d in direction:   px, py = (x + y for x, y in zip(start, operation[d]))   if px < 0 or px >= sx or py < 0 or py >= sy:    pass   else:    if dfs[py][px] is not 1:     mx = 2*x + 1     my = 2*y + 1     if d == 1:      maze[my-1][mx] = ' '     elif d == 2:      maze[my+1][mx] = ' '     elif d == 3:      maze[my][mx-1] = ' '     elif d == 4:      maze[my][mx+1] = ' '     generateMaze((px,py))  generateMaze((0,0)) show(dfs) show(maze) 

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 泰安市| 乌什县| 霍邱县| 祁门县| 德阳市| 虞城县| 巴彦淖尔市| 娱乐| 南雄市| 武冈市| 新龙县| 自贡市| 竹山县| 扬州市| 五常市| 通江县| 邯郸县| 嘉黎县| 永康市| 宝鸡市| 农安县| 扬中市| 鹤岗市| 德清县| 阳谷县| 远安县| 洛南县| 呼伦贝尔市| 新昌县| 宁蒗| 南川市| 梅州市| 长葛市| 建德市| 秦安县| 赣州市| 景宁| 洛浦县| 镇坪县| 洛浦县| 封开县|