Python深度优先算法生成迷宫

Python深度优先算法生成迷宫,第1张

概述本文实例为大家分享了Python深度优先算法生成迷宫,供大家参考,具体内容如下

本文实例为大家分享了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使用Tkinter实现机器人走迷宫Python基于分水岭算法解决走迷宫游戏示例Python使用回溯法子集树模板解决迷宫问题示例Python基于递归算法实现的走迷宫问题用Python代码来解图片迷宫的方法整理python实现的生成随机迷宫算法核心代码分享(含游戏完整代码)一道python走迷宫算法题 总结

以上是内存溢出为你收集整理的Python深度优先算法生成迷宫全部内容,希望文章能够帮你解决Python深度优先算法生成迷宫所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1200694.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-04
下一篇 2022-06-04

发表评论

登录后才能评论

评论列表(0条)

保存