下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
第Python實(shí)現(xiàn)隨機(jī)生成迷宮并自動(dòng)尋路next_pos=(curr_pos[0]+_xy[i],curr_pos[1]+_xy[i+1])
if(0=next_pos[0]sizeand
0=next_pos[1]sizeand
next_posnotinroad):
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()
defdfs_getans(curr_pos):
ans_road.add(curr_pos)
if(size-1,size-1)inans_road:
return
foriinrange(4):
next_pos=(curr_pos[0]+_xy[i]//2,curr_pos[1]+_xy[i+1]//2)
if(0=next_pos[0]sizeand
0=next_pos[1]sizeand
next_posinroadand
next_posnotinans_roadand
(size-1,size-1)notinans_road):
dfs_getans(next_pos)
if(size-1,size-1)notinans_road:
ans_road.remove(curr_pos)
dfs_getans((0,0))
print(len(ans_road))
foriinrange(0,size):
forjinrange(0,size):
print((Back.WHITE+'')if(i,j)inroadelse(Back.BLACK+''),end='')
print()
wall_width=1
cell_size=5
image=bmp((size+3)*cell_size-wall_width,(size+3)*cell_size-wall_width,0x000000)
foriinrange(size+3):
forjinrange(size+3):
if(i-1,j-1)inroad:
image.paint_rect(i*cell_size,j*cell_size,cell_size*2-wall_width,cell_size*2-wall_width,0xffffff)
file_name="%dmaze.bmp"%size
image.save_image(file_name)
os.system(file_name)
forpinans_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"%size
image.save_image(file_name)
os.system(file_name)
效果:
相比深度優(yōu)先的,這種迷宮會(huì)更加“直”一些
lua版:
大體上是深搜,加了一定的隨機(jī)性使得搜索過程中有一定概率暫時(shí)放棄當(dāng)前路徑。見表stop_points,(第7行、第74行及其后面的repeat循環(huán))
local_xy={0,2,0,-2,0}
localsize=41
localbase=size+1
localroad={}
stop_points={}
functiondfs(curr_x,curr_y)
road[curr_x*base+curr_y]=true
ifmath.random(1,10)=3then
stop_points[curr_x*base+curr_y]=true
return
--os.execute("cls")
--print_map()
localpermutation={1,2,3,4}
fori=1,4do
locall=math.random(1,4)
localr=math.random(1,4)
permutation[l],permutation[r]=permutation[r],permutation[l]
fori=1,4do
localnext_x=curr_x+_xy[permutation[i]]
localnext_y=curr_y+_xy[permutation[i]+1]
ifnext_x=1andnext_x=sizeand
next_y=1andnext_y=sizeand
road[next_x*base+next_y]==nilthen
localmid_x=math.floor((curr_x+next_x)/2)
localmid_y=math.floor((curr_y+next_y)/2)
road[mid_x*base+mid_y]=true
dfs(next_x,next_y)
localans_geted=false
localparent={}
functionget_ans(curr_x,curr_y)
--print(curr_x,curr_y)
fori=1,4do
next_x=(curr_x+math.floor(_xy[i])/2)
next_y=(curr_y+math.floor(_xy[i+1])/2)
--print(next_x,next_y)
ifnext_x=1andnext_x=sizeand
next_y=1andnext_y=sizeand
road[next_x*base+next_y]and
parent[next_x*base+next_y]==nil
then
parent[next_x*base+next_y]=curr_x*base+curr_y
get_ans(next_x,next_y)
localans_road={}
functionprint_map()
fori=0,size+1do
localline=""
forj=0,size+1do
ifans_road[i*base+j]then
line=line..".."
elseifroad[i*base+j]==truethen
line=line..""
else
line=line.."HH"
print(line)
stop_points[1*base+1]=true
--createmaze
repeat
localhas_point
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2026浙江開化農(nóng)村商業(yè)銀行寒假實(shí)習(xí)生社會(huì)實(shí)踐活動(dòng)招募備考考試試題附答案解析
- 2025廣東佛山市順德區(qū)沙滘初級(jí)中學(xué)第二學(xué)期臨聘教師招聘備考考試試題附答案解析
- 2026福建南平市建陽區(qū)文化體育和旅游局招聘1人備考考試題庫附答案解析
- 物業(yè)公司生產(chǎn)責(zé)任制度
- 原材料生產(chǎn)過程管理制度
- 2026重慶市萬州區(qū)燕山鄉(xiāng)人民政府招聘全日制公益性崗位1人備考考試試題附答案解析
- 倉鼠生產(chǎn)管理員工制度
- 生產(chǎn)企業(yè)黑名單制度
- 2026年河北承德市教育局公開選聘急需緊缺學(xué)科教師39名參考考試題庫附答案解析
- 戒毒所生產(chǎn)車間制度
- 北京通州產(chǎn)業(yè)服務(wù)有限公司招聘參考題庫必考題
- 兒科MDT臨床技能情景模擬培訓(xùn)體系
- 【高三上】2026屆12月八省聯(lián)考(T8聯(lián)考)語文試題含答案
- 護(hù)理不良事件根本原因分析
- 社會(huì)心理學(xué)考試題及答案
- 醫(yī)療器械經(jīng)營企業(yè)質(zhì)量管理體系文件(2025版)(全套)
- 出鐵廠鐵溝澆注施工方案
- 2025年中小學(xué)教師正高級(jí)職稱評(píng)聘答辯試題(附答案)
- 現(xiàn)代企業(yè)管理體系架構(gòu)及運(yùn)作模式
- 古建筑設(shè)計(jì)工作室創(chuàng)業(yè)
- 公司酶制劑發(fā)酵工工藝技術(shù)規(guī)程
評(píng)論
0/150
提交評(píng)論