欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python基于遞歸算法實(shí)現(xiàn)的走迷宮問(wèn)題

 更新時(shí)間:2017年08月04日 12:04:11   作者:葉赫那拉坤  
這篇文章主要介紹了Python基于遞歸算法實(shí)現(xiàn)的走迷宮問(wèn)題,結(jié)合迷宮問(wèn)題簡(jiǎn)單分析了Python遞歸算法的定義與使用技巧,需要的朋友可以參考下

本文實(shí)例講述了Python基于遞歸算法實(shí)現(xiàn)的走迷宮問(wèn)題。分享給大家供大家參考,具體如下:

什么是遞歸?

簡(jiǎn)單地理解就是函數(shù)調(diào)用自身的過(guò)程就稱之為遞歸。

什么時(shí)候用到遞歸?

如果一個(gè)問(wèn)題可以表示為更小規(guī)模的迭代運(yùn)算,就可以使用遞歸算法。
迷宮問(wèn)題:一個(gè)由0或1構(gòu)成的二維數(shù)組中,假設(shè)1是可以移動(dòng)到的點(diǎn),0是不能移動(dòng)到的點(diǎn),如何從數(shù)組中間一個(gè)值為1的點(diǎn)出發(fā),每一只能朝上下左右四個(gè)方向移動(dòng)一個(gè)單位,當(dāng)移動(dòng)到二維數(shù)組的邊緣,即可得到問(wèn)題的解,類似的問(wèn)題都可以稱為迷宮問(wèn)題。

在python中可以使用list嵌套表示二維數(shù)組。假設(shè)一個(gè)6*6的迷宮,問(wèn)題時(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]]

針對(duì)這個(gè)迷宮問(wèn)題,我們可以使用遞歸的思想很好的解決。對(duì)于數(shù)組中的一個(gè)點(diǎn),該點(diǎn)的四個(gè)方向可以通過(guò)橫縱坐標(biāo)的加減輕松的表示,每當(dāng)移動(dòng)的一個(gè)可移動(dòng)的點(diǎn)時(shí)候,整個(gè)問(wèn)題又變?yōu)楹统跏紶顟B(tài)一樣的問(wèn)題,繼續(xù)搜索四個(gè)方向找可以移動(dòng)的點(diǎn),知道移動(dòng)到數(shù)組的邊緣。

所以我們可以這樣編碼:

# 判斷坐標(biāo)的有效性,如果超出數(shù)組邊界或是不滿足值為1的條件,說(shuō)明該點(diǎn)無(wú)效返回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):
  # 如果位置是迷宮的出口,說(shuō)明成功走出迷宮
  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)記,防止折回
    # 針對(duì)四個(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 # 無(wú)路可走說(shuō)明,沒(méi)有解 
  return True
walk(maze,3,3)

遞歸是個(gè)好東西呀!

PS:本站還有一個(gè)無(wú)限迷宮游戲,基于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)典教程

希望本文所述對(duì)大家Python程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • django實(shí)現(xiàn)同一個(gè)ip十分鐘內(nèi)只能注冊(cè)一次的實(shí)例

    django實(shí)現(xiàn)同一個(gè)ip十分鐘內(nèi)只能注冊(cè)一次的實(shí)例

    下面小編就為大家?guī)?lái)一篇django實(shí)現(xiàn)同一個(gè)ip十分鐘內(nèi)只能注冊(cè)一次的實(shí)例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-11-11
  • Python3用2行代碼生成動(dòng)態(tài)二維碼詳解

    Python3用2行代碼生成動(dòng)態(tài)二維碼詳解

    這篇文章主要介紹了兩行Python代碼制作動(dòng)態(tài)二維碼的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-10-10
  • Python內(nèi)建屬性getattribute攔截器使用詳解

    Python內(nèi)建屬性getattribute攔截器使用詳解

    這篇文章主要為大家介紹了Python內(nèi)建屬性getattribute攔截器使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-05-05
  • Python設(shè)置Word全局樣式和文本樣式的示例代碼

    Python設(shè)置Word全局樣式和文本樣式的示例代碼

    這篇文章主要介紹了如何利用Python對(duì)Word內(nèi)容進(jìn)行各種樣式的設(shè)置,讓其能夠看起來(lái)更加的美觀。文中的示例代碼講解詳細(xì),需要的可以參考一下
    2022-05-05
  • python中異常捕獲方法詳解

    python中異常捕獲方法詳解

    異常信息的獲取對(duì)于程序的調(diào)試非常重要,可以有助于快速定位有錯(cuò)誤程序語(yǔ)句的位置。下面介紹幾種python中獲取異常信息的方法,希望小伙伴們能夠喜歡
    2017-03-03
  • python實(shí)現(xiàn)梯度下降法

    python實(shí)現(xiàn)梯度下降法

    這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)梯度下降法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-03-03
  • 基于python實(shí)現(xiàn)從尾到頭打印鏈表

    基于python實(shí)現(xiàn)從尾到頭打印鏈表

    這篇文章主要介紹了基于python實(shí)現(xiàn)從尾到頭打印鏈表,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-11-11
  • win10環(huán)境下python3.5安裝步驟圖文教程

    win10環(huán)境下python3.5安裝步驟圖文教程

    本文通過(guò)圖文并茂的形式給大家介紹了win10環(huán)境下python3.5安裝步驟,需要的朋友可以參考下
    2017-02-02
  • opencv+圖像處理(Image Processing in OpenCV) 4-0改變顏色空間的過(guò)程

    opencv+圖像處理(Image Processing in OpenCV) 

    這篇文章主要介紹了opencv+圖像處理(Image Processing in OpenCV) 4-0改變顏色空間,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-04-04
  • Python函數(shù)中不定長(zhǎng)參數(shù)的寫法

    Python函數(shù)中不定長(zhǎng)參數(shù)的寫法

    今天小編就為大家分享一篇關(guān)于Python函數(shù)中不定長(zhǎng)參數(shù)的寫法,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2019-02-02

最新評(píng)論