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

首頁(yè) > 編程 > Python > 正文

Python深度優(yōu)先算法生成迷宮

2020-01-04 16:03:15
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

本文實(shí)例為大家分享了Python深度優(yōu)先算法生成迷宮,供大家參考,具體內(nèi)容如下

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) 

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持VEVB武林網(wǎng)。


注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到python教程頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 五大连池市| 敖汉旗| 绥阳县| 陆良县| 邓州市| 轮台县| 利川市| 巩义市| 和林格尔县| 开封县| 兴宁市| 郎溪县| 保亭| 龙游县| 闵行区| 长宁县| 富阳市| 陇川县| 兰考县| 霍城县| 临清市| 大名县| 苏尼特左旗| 安平县| 错那县| 舞钢市| 绥宁县| 陆川县| 银川市| 济南市| 乌拉特中旗| 两当县| 高青县| 德格县| 和林格尔县| 个旧市| 新干县| 临城县| 崇阳县| 肃宁县| 富源县|