Python实现 深度优先算法生成迷宫,python迷宫, import r
文章由Byrx.net分享于2019-03-23 04:03:49
Python实现 深度优先算法生成迷宫,python迷宫, import r
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)
相关内容
- Python sql server和postgresql的表结构转换,pythonpostgresql,#
- Python 实现简单的矩阵,python实现矩阵, #!/usr/b
- 文件去重,文件,__author__ =
- python解析网页的字符编码,python解析字符,import urlli
- python密码生成器,python生成器,python密码生成器,
- 基于Selenium的用户登录自动化测试用例,selenium用例,#
- 分享一个metasploit快速测试脚本的TIPS,metasploittips,相信
- 用Python杀掉windows平台下的进程,pythonwindows,# "这段代
- Python 生成随机密码,python生成,import strin
- Python将阿拉伯数字转化为中文大写,python阿拉伯,利用
评论关闭