日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Python實現隨機生成迷宮并自動尋路

瀏覽:21日期:2022-06-17 08:04:37
目錄Python深搜版:Python 廣搜版lua版:Python深搜版:

核心在于帶隨機的深搜(見代碼第23到27行,其實也可以用22行代替這幾行代碼,你可以試著把第24行的數字4改大或者改小,即調整隨機程度)

import osimport randomfrom queue import Queueimport numpyimport coloramafrom colorama import Fore, Back, Styleimport sys from bmpEditor import bmpcolorama.init()# numpy.random.seed(1)_xy = [0,2,0,-2,0]size = 31sys.setrecursionlimit(100000000)road = set()def dfs(curr_pos):road.add(curr_pos)# for i in numpy.random.permutation(4):p = [0,1,2,3]for i in range(4):l = random.randint(0,3)r = random.randint(0,3)p[l], p[r] = p[r], p[l]for i in p:next_pos = (curr_pos[0] + _xy[i], curr_pos[1] + _xy[i+1])if (0<=next_pos[0]<size and0<=next_pos[1]<size andnext_pos not in road ):road.add(((curr_pos[0] + next_pos[0])/2, (curr_pos[1] + next_pos[1])/2))dfs(next_pos)dfs((0,0))q = Queue()q.put((0,0))ans_road = set()def dfs_getans(curr_pos):# print(curr_pos)ans_road.add(curr_pos)if (size-1, size-1) in ans_road:returnfor i in range(4):next_pos = (curr_pos[0] + _xy[i]//2, curr_pos[1] + _xy[i+1]//2)if (0<=next_pos[0]<size and0<=next_pos[1]<size andnext_pos in road andnext_pos not in ans_road and(size-1, size-1) not in ans_road):dfs_getans(next_pos)if (size-1, size-1) not in ans_road:ans_road.remove(curr_pos)dfs_getans((0,0))for i in range(size):for j in range(size):print((Back.WHITE + ’ ’) if (i,j) in road else (Back.BLACK + ’ ’), end=’ ’)print()wall_width = 2cell_size = 6image = bmp((size+3)*cell_size-wall_width, (size+3)*cell_size-wall_width, 0x000000)for i in range(size+3):for j in range(size+3):if (i-1, j-1) in road:image.paint_rect(i*cell_size, j*cell_size, cell_size*2-wall_width, cell_size*2-wall_width, 0xffffff)file_name = '%dmaze.bmp'%sizeimage.save_image(file_name)os.system(file_name)for p in ans_road:# image.paint_rect(p[0]+1, p[1]+1)image.paint_rect((p[0]+1)*cell_size + (cell_size - wall_width)//2,(p[1]+1)*cell_size + (cell_size - wall_width)//2,cell_size, cell_size,0xff0000)file_name = '%dans.bmp'%sizeimage.save_image(file_name)os.system(file_name)

效果

3131:

Python實現隨機生成迷宮并自動尋路

Python實現隨機生成迷宮并自動尋路

8181:

Python實現隨機生成迷宮并自動尋路

Python實現隨機生成迷宮并自動尋路

坐標系有翻轉,控制臺中的左上角對應圖片中的左下角

其中bmpEditor不是官方庫,代碼地址(文件名為bmpEditor.py,和這以上代碼放同一個路徑下即可)

Python 廣搜版

在隊列的基礎上把隊列中的元素順序打亂(第24行)

import osimport randomfrom queue import Queueimport numpyimport coloramafrom colorama import Fore, Back, Styleimport sys import random from bmpEditor import bmpcolorama.init()numpy.random.seed(1)_xy = [0,2,0,-2,0]size = 59sys.setrecursionlimit(size*size//4+size)q = []q.append((0,0))road = set()road.add((0,0))while len(q) != 0:random.shuffle(q)curr_pos = q.pop()# print(curr_pos)for i in range(4):next_pos = (curr_pos[0] + _xy[i], curr_pos[1] + _xy[i+1])if (0<=next_pos[0]<size and0<=next_pos[1]<size andnext_pos not in road ):road.add( ((curr_pos[0] + next_pos[0])//2, (curr_pos[1] + next_pos[1])//2) )q.append(next_pos)road.add(next_pos)ans_road = set()def dfs_getans(curr_pos):ans_road.add(curr_pos)if (size-1, size-1) in ans_road:returnfor i in range(4):next_pos = (curr_pos[0] + _xy[i]//2, curr_pos[1] + _xy[i+1]//2)if (0<=next_pos[0]<size and0<=next_pos[1]<size andnext_pos in road andnext_pos not in ans_road and(size-1, size-1) not in ans_road):dfs_getans(next_pos)if (size-1, size-1) not in ans_road:ans_road.remove(curr_pos)dfs_getans((0,0))print(len(ans_road))for i in range(0, size):for j in range(0, size):print((Back.WHITE + ’ ’) if (i,j) in road else (Back.BLACK + ’ ’), end=’ ’)print()wall_width = 1cell_size = 5image = bmp((size+3)*cell_size-wall_width, (size+3)*cell_size-wall_width, 0x000000)for i in range(size+3):for j in range(size+3):if (i-1, j-1) in road:image.paint_rect(i*cell_size, j*cell_size, cell_size*2-wall_width, cell_size*2-wall_width, 0xffffff)file_name = '%dmaze.bmp'%sizeimage.save_image(file_name)os.system(file_name)for p in ans_road:# image.paint_rect(p[0]+1, p[1]+1)image.paint_rect((p[0]+1)*cell_size + (cell_size - wall_width)//2,(p[1]+1)*cell_size + (cell_size - wall_width)//2,cell_size, cell_size,0xff0000)file_name = '%dans.bmp'%sizeimage.save_image(file_name)os.system(file_name)

效果:

Python實現隨機生成迷宮并自動尋路

Python實現隨機生成迷宮并自動尋路

相比深度優先的,這種迷宮會更加“直”一些

lua版:

大體上是深搜,加了一定的隨機性使得搜索過程中有一定概率暫時放棄當前路徑。見表stop_points,(第7行、第74行及其后面的repeat循環)

local _xy = {0,2,0,-2,0}local size = 41local base = size+1local road = {}stop_points = {}function dfs(curr_x, curr_y)road[curr_x*base+curr_y] = trueif math.random(1,10) <= 3 thenstop_points[curr_x*base+curr_y] = truereturnend-- os.execute('cls')-- print_map()local permutation = {1,2,3,4}for i=1, 4 dolocal l = math.random(1,4)local r = math.random(1,4)permutation[l], permutation[r] = permutation[r], permutation[l]endfor i=1, 4 dolocal next_x = curr_x+_xy[permutation[i]]local next_y = curr_y+_xy[permutation[i]+1]if next_x>=1 and next_x<=size andnext_y>=1 and next_y<=size androad[next_x*base+next_y] == nil thenlocal mid_x = math.floor((curr_x+next_x)/2)local mid_y = math.floor((curr_y+next_y)/2)road[mid_x*base+mid_y] = truedfs(next_x, next_y)endendendlocal ans_geted = falselocal parent = {}function get_ans(curr_x, curr_y)-- print(curr_x, curr_y)for i=1, 4 donext_x = (curr_x + math.floor(_xy[i])/2 )next_y = (curr_y + math.floor(_xy[i+1])/2 )-- print(next_x, next_y)if next_x >= 1 and next_x <= size andnext_y >= 1 and next_y <= size androad[next_x*base+next_y] andparent[next_x*base+next_y]==nilthenparent[next_x*base+next_y] = curr_x*base+curr_yget_ans(next_x, next_y)endendendlocal ans_road = {}function print_map()for i=0, size+1 dolocal line = ''for j=0, size+1 doif ans_road [i*base+j] thenline = line..'..'elseif road[i*base+j]==true thenline = line..' 'elseline = line..'HH'endendprint(line)endendstop_points[1*base+1] = true-- create mazerepeatlocal has_point = falsefor v,_ in pairs(stop_points) dohas_point = truestop_points[v] = nildfs(math.floor(v/base), v%base)breakend-- print(has_point)until not has_pointget_ans(1,1)parent[1*base+1] = nilprint('')-- for k,v in pairs(parent) do-- print(string.format('[%d,%d]->[%d,%d]', math.floor(k/base), k%base, math.floor(v/base), v%base))-- endprint('')local x = sizelocal y = sizerepeat-- print(x,y)ans_road[x*base+y] = truelocal v = parent[x*base+y]x = math.floor(v/base)y = v%baseuntil --[[(x==1 and y== 1)]] not parent[x*base+y]ans_road[1*base+1] = trueprint_map()

效果:

4141:

Python實現隨機生成迷宮并自動尋路

8989

Python實現隨機生成迷宮并自動尋路

到此這篇關于Python實現隨機生成迷宮并自動尋路的文章就介紹到這了,更多相關Python生成迷宮并自動尋路內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Python 編程
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
91精品国产自产在线丝袜啪| 久久99久久久精品欧美| 久久人人99| 成人精品天堂一区二区三区| 久久不射网站| 韩国女主播一区二区三区| 超碰在线99| 色欧美自拍视频| 黄色日韩在线| 国产福利一区二区三区在线播放| 伊人精品一区| 精品国产中文字幕第一页| 欧美日韩激情在线一区二区三区| 欧美日本不卡| 国内揄拍国内精品久久| 亚洲一区二区三区久久久| 成人在线视频免费| 日韩精品第一| 蜜桃av一区二区三区电影| 婷婷激情一区| 国产成人黄色| 精品国产亚洲一区二区三区在线| 日本不卡的三区四区五区| 欧美日韩国产高清| 国产精品97| 91九色精品| 九色精品91| 国产亚洲在线观看| 日韩国产欧美三级| 麻豆中文一区二区| 免费日韩一区二区三区| 国产精品.xx视频.xxtv| 欧美日韩1区| 国产欧美在线| 国产精品羞羞答答在线观看| 欧美日韩一区二区三区不卡视频| 日本久久一区| 久久久国产精品网站| 国产精品午夜一区二区三区| 久久不卡日韩美女| 国产一区二区精品久| 国产超碰精品| 亚洲深夜影院| 在线观看视频免费一区二区三区| 亚洲女同中文字幕| 日韩有码av| av资源新版天堂在线| 激情欧美一区二区三区| 午夜在线一区| 欧美aaaaaa午夜精品| 欧美成人基地| 99综合视频| 国产网站在线| 成人看片网站| 亚洲人成网77777色在线播放| 久久中文精品| 99riav1国产精品视频| 国产精品久久久久久久免费观看 | 亚洲视频二区| 国产精品亚洲综合久久| av免费不卡国产观看| 亚洲欧美高清| 伊人久久在线| 欧美日韩调教| 亚洲一区亚洲| 久久精品二区亚洲w码| 伊人精品久久| 精品精品国产三级a∨在线| 国产精品婷婷| 99精品网站| 国精品产品一区| 日韩精品亚洲一区二区三区免费| 88xx成人免费观看视频库| 国产精品一区2区3区| 亚洲精品一区二区妖精| 成人日韩精品| 日本精品影院| 欧美不卡在线| 日韩大片在线| 日韩在线一二三区| 中文字幕av亚洲精品一部二部| 精品一区视频| 在线观看一区| 色综合视频一区二区三区日韩| 老色鬼久久亚洲一区二区| 午夜欧美精品| 色婷婷综合网| 久久中文亚洲字幕| 国产91欧美| 国产精品theporn| 日韩精品欧美成人高清一区二区| 国产一在线精品一区在线观看| 久久亚洲精品中文字幕| 日韩高清三区| 中文字幕av一区二区三区人| 亚洲精品网址| 国产精品人人爽人人做我的可爱| 国产欧美日韩一区二区三区四区 | 99视频在线精品国自产拍免费观看| 奇米色欧美一区二区三区| 欧美中文字幕| 在线精品一区二区| 中文字幕一区二区av| 午夜在线一区| 日韩精品五月天| 久久国产日本精品| 成人精品动漫一区二区三区| 精品午夜久久| 亚洲人成在线网站| 激情婷婷欧美| 久久aⅴ国产紧身牛仔裤| 一本综合精品| 国产福利一区二区精品秒拍| 激情不卡一区二区三区视频在线| 国产激情一区| 国产成人久久| 亚洲激情中文| 一区二区不卡| 精品免费av| 免费日韩成人| 日本一区中文字幕| 国产精品videosex极品| 91青青国产在线观看精品| 久久精品国产68国产精品亚洲| 国产日韩在线观看视频| 欧美激情精品| 国产亚洲在线观看| 国产精品久久久久久av公交车| 水蜜桃久久夜色精品一区| 午夜国产精品视频| 国产精品第一| aa国产精品| 欧美日韩亚洲国产精品| 激情久久久久久| 日韩高清一区在线| 综合国产在线| 中文字幕成在线观看| 国产伊人久久| 欧美另类专区| 美女福利一区二区三区| 亚州欧美在线| 成人精品亚洲| 另类综合日韩欧美亚洲| 香蕉久久久久久久av网站| 久久中文在线| 亚洲欧美日韩专区| 日韩三区免费| 免费高潮视频95在线观看网站| 国产精品久久免费视频| 亚洲狼人精品一区二区三区| 久久不卡国产精品一区二区| 亚洲精品视频一二三区| 99精品99| 综合干狼人综合首页| 亚洲精品极品少妇16p| 久久久精品五月天| 伊人久久av| 国产精品久久久久蜜臀| 色爱综合网欧美| 成人高清一区| 精品国产成人| 久久精品一区二区国产| 亚洲精一区二区三区| 91精品观看| 午夜电影亚洲| 国产精品15p| 久久精品99国产精品| 水野朝阳av一区二区三区| 亚洲精品进入| 欧美日韩激情在线一区二区三区| 色婷婷狠狠五月综合天色拍| 午夜欧美视频| 夜夜嗨av一区二区三区网站四季av| 999国产精品| 亚洲一区日韩| 欧美日韩亚洲三区| 日韩电影在线视频| 91精品精品| 综合欧美亚洲| 美日韩一区二区三区| 欧美日韩黄网站| 国产日产一区| 天堂av在线| 一区免费视频| 久久不见久久见中文字幕免费| 福利在线免费视频| 丝袜美腿成人在线| 国产精品久久久亚洲一区| 日韩精品永久网址| 亚洲综合日本| xxxxx性欧美特大| 日韩午夜视频在线| 国产精品精品国产一区二区| 欧美成人精品| 麻豆精品在线视频| 国产精品亚洲二区| 久久婷婷久久| 国产精品亚洲综合色区韩国| 黄色日韩精品| 日韩久久一区二区三区|