Python深度优先算法生成迷宫
2018-01-22 10:33
936 查看
本文实例为大家分享了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)
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
相关文章推荐
- 深度优先算法生成迷宫——Python实现
- 关于用深度优先算法生成迷宫与寻找路径的一些回忆
- python实现的生成随机迷宫算法核心代码分享(含游戏完整代码)
- python实现的生成随机迷宫算法核心代码分享(含游戏完整代码)
- python+pygame 生成迷宫
- python生成验证码
- 自定义RFS关键字库中的关键字(使用python随机生成身份证号码)
- python 生成有效的四要素
- Python实现随机生成有效手机号码及身份证功能示例
- 迷宫生成算法
- python生成透时图片and 写文字
- python 程序生成exe文件
- php中使用python生成excel报表
- Python 十分钟学会用任意中文文本生成词云
- python之随机数生成方法汇总
- python自动生成执行集群操作脚本
- python 语法树生成过程
- 利用doxygen生成python文档
- Python生成自定义类并添加自定义方法
- Python实现抓取网页生成Excel文件的方法示例