Python基于遞歸算法實(shí)現(xiàn)的走迷宮問題
本文實(shí)例講述了Python基于遞歸算法實(shí)現(xiàn)的走迷宮問題。分享給大家供大家參考,具體如下:
什么是遞歸?
簡單地理解就是函數(shù)調(diào)用自身的過程就稱之為遞歸。
什么時(shí)候用到遞歸?
如果一個(gè)問題可以表示為更小規(guī)模的迭代運(yùn)算,就可以使用遞歸算法。
迷宮問題:一個(gè)由0或1構(gòu)成的二維數(shù)組中,假設(shè)1是可以移動到的點(diǎn),0是不能移動到的點(diǎn),如何從數(shù)組中間一個(gè)值為1的點(diǎn)出發(fā),每一只能朝上下左右四個(gè)方向移動一個(gè)單位,當(dāng)移動到二維數(shù)組的邊緣,即可得到問題的解,類似的問題都可以稱為迷宮問題。
在python中可以使用list嵌套表示二維數(shù)組。假設(shè)一個(gè)6*6的迷宮,問題時(shí)從該數(shù)組坐標(biāo)[3][3]出發(fā),判斷能不能成功的走出迷宮。
maze=[[1,0,0,1,0,1], [1,1,1,0,1,0], [0,0,1,0,1,0], [0,1,1,1,0,0], [0,0,0,1,0,0], [1,0,0,0,0,0]]
針對這個(gè)迷宮問題,我們可以使用遞歸的思想很好的解決。對于數(shù)組中的一個(gè)點(diǎn),該點(diǎn)的四個(gè)方向可以通過橫縱坐標(biāo)的加減輕松的表示,每當(dāng)移動的一個(gè)可移動的點(diǎn)時(shí)候,整個(gè)問題又變?yōu)楹统跏紶顟B(tài)一樣的問題,繼續(xù)搜索四個(gè)方向找可以移動的點(diǎn),知道移動到數(shù)組的邊緣。
所以我們可以這樣編碼:
# 判斷坐標(biāo)的有效性,如果超出數(shù)組邊界或是不滿足值為1的條件,說明該點(diǎn)無效返回False,否則返回True。
def valid(maze,x,y):
if (x>=0 and x<len(maze) and y>=0 and y<len(maze[0]) and maze[x][y]==1):
return True
else:
return False
# 移步函數(shù)實(shí)現(xiàn)
def walk(maze,x,y):
# 如果位置是迷宮的出口,說明成功走出迷宮
if(x==0 and y==0):
print("successful!")
return True
# 遞歸主體實(shí)現(xiàn)
if valid(maze,x,y):
# print(x,y)
maze[x][y]=2 # 做標(biāo)記,防止折回
# 針對四個(gè)方向依次試探,如果失敗,撤銷一步
if not walk(maze,x-1,y):
maze[x][y]=1
elif not walk(maze,x,y-1):
maze[x][y]=1
elif not walk(maze,x+1,y):
maze[x][y]=1
elif not walk(maze,x,y+1):
maze[x][y]=1
else:
return False # 無路可走說明,沒有解
return True
walk(maze,3,3)
遞歸是個(gè)好東西呀!
PS:本站還有一個(gè)無限迷宮游戲,基于JS實(shí)現(xiàn),提供給大家參考一下:
在線迷宮小游戲:
http://tools.jb51.net/games/migong
更多關(guān)于Python相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》及《Python入門與進(jìn)階經(jīng)典教程》
希望本文所述對大家Python程序設(shè)計(jì)有所幫助。
相關(guān)文章
Python中的google authenticator認(rèn)證過程
文章介紹了使用Python 3.7生成Google Authenticator所需密鑰的步驟,包括使用pyotp模塊生成密鑰、生成二維碼圖片以及通過客戶端掃描二維碼進(jìn)行二次認(rèn)證的實(shí)現(xiàn)原理2024-11-11
Python使用paramiko連接遠(yuǎn)程服務(wù)器執(zhí)行Shell命令的實(shí)現(xiàn)
這篇文章主要介紹了Python使用paramiko連接遠(yuǎn)程服務(wù)器執(zhí)行Shell命令的實(shí)現(xiàn),本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-03-03
Python下利用BeautifulSoup解析HTML的實(shí)現(xiàn)
這篇文章主要介紹了Python下利用BeautifulSoup解析HTML的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-01-01
python global的創(chuàng)建和修改實(shí)例講解
在本篇文章里小編給大家整理了一篇關(guān)于python global的創(chuàng)建和修改實(shí)例講解內(nèi)容,有興趣的朋友們可以學(xué)習(xí)下。2021-09-09
python實(shí)現(xiàn)轉(zhuǎn)圈打印矩陣
這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)轉(zhuǎn)圈打印矩陣,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-03-03
Python實(shí)現(xiàn)把數(shù)字轉(zhuǎn)換成中文
這篇文章主要介紹了Python實(shí)現(xiàn)把數(shù)字轉(zhuǎn)換成中文,一般用于數(shù)字金額轉(zhuǎn)中文大寫金額,即將阿拉伯?dāng)?shù)字轉(zhuǎn)換為大寫的中文,需要的朋友可以參考下2015-06-06

