Python基于遞歸算法實現(xiàn)的漢諾塔與Fibonacci數(shù)列示例
本文實例講述了Python基于遞歸算法實現(xiàn)的漢諾塔與Fibonacci數(shù)列。分享給大家供大家參考,具體如下:
這里我們通過2個例子,學(xué)習(xí)python中遞歸的使用。
1. 找出Fibonacci數(shù)列中,下標(biāo)為 n 的數(shù)(下標(biāo)從0計數(shù))
Fibonacci數(shù)列的形式是這樣的:0,1,1,2,3,5,8,13……
① 使用while循環(huán),python2代碼如下:
def fib(n):
a,b=0,1
count=0
while count<n:
a,b=b,a+b
count=count+1
print a
運行結(jié)果如下:
>>> fib(0)
0
>>> fib(1)
1
>>> fib(2)
1
>>> fib(3)
2
>>> fib(4)
3
>>> fib(5)
5
② 使用遞歸(遞歸必須要有邊界條件),python2代碼如下:
def fib(n):
if n==0 or n==1:#遞歸的邊界條件
return n
else:
return fib(n-1)+fib(n-2)
運行結(jié)果如下:
>>> fib(0)
0
>>> fib(1)
1
>>> fib(2)
1
>>> fib(3)
2
>>> fib(4)
3
>>> fib(5)
5
遞歸是最能表現(xiàn)計算思維的算法之一,我們以f(4)為例,看一下遞歸的執(zhí)行過程:

同一程序,使用遞歸雖然程序簡潔,但遞歸的執(zhí)行效率要比循環(huán)低,系統(tǒng)的資源消耗比循環(huán)大。因為遞歸是一層一層地往里面調(diào)用,結(jié)束后又一層一層地返回,所以遞歸的執(zhí)行效率并不高。那為什么還要使用遞歸呢?因為有一些問題,我們找不到非常明顯的循環(huán)方案,但容易找到明顯的遞歸方案。比如說著名的漢諾塔問題。
2. 漢諾塔
下圖是一個簡化版的漢諾塔游戲,只有4個盤子:

漢諾塔游戲規(guī)則如下:

python2代碼如下:
def hanoi(a,b,c,n):
if n==1:#遞歸結(jié)束條件
print a,'->',c
else:
hanoi(a,c,b,n-1)
print a,'->',c
hanoi(b,a,c,n-1)
運行結(jié)果:
>>> hanoi('A','B','C',1)
A -> C
>>> hanoi('A','B','C',2)
A -> B
A -> C
B -> C
>>> hanoi('A','B','C',3)
A -> C
A -> B
C -> B
A -> C
B -> A
B -> C
A -> C
更多關(guān)于Python相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》、《Python入門與進(jìn)階經(jīng)典教程》及《Python文件與目錄操作技巧匯總》
希望本文所述對大家Python程序設(shè)計有所幫助。
相關(guān)文章
python通過ElementTree操作XML獲取結(jié)點讀取屬性美化XML
本文講解如何通過ElementTree解析XML,獲取兒子結(jié)點、插入兒子結(jié)點、操作屬性、美化XML2013-12-12
python3.6.3安裝圖文教程 TensorFlow安裝配置方法
這篇文章主要為大家詳細(xì)介紹了python3.6.3及TensorFlow安裝配置方法圖文教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-09-09
利用PyQt5中QLabel組件實現(xiàn)亞克力磨砂效果
Windows10 在 UWP 應(yīng)用中支持亞克力畫刷,可以在部件的底部繪制亞克力效果的背景圖。本文將使用QLabel來模擬這個磨砂過程,感興趣的可以了解一下2022-03-03
基于PyTorch的permute和reshape/view的區(qū)別介紹
這篇文章主要介紹了基于PyTorch的permute和reshape/view的區(qū)別介紹,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-06-06
python實現(xiàn)顏色空間轉(zhuǎn)換程序(Tkinter)
這篇文章主要介紹了基于Tkinter利用python實現(xiàn)顏色空間轉(zhuǎn)換程序,感興趣的小伙伴們可以參考一下2015-12-12
利用Python實現(xiàn)Markdown文檔格式轉(zhuǎn)換詳解
這篇文章主要介紹了如何利用Python中的MarkItDown庫將多種文件高效轉(zhuǎn)換為Markdown文本,以及如何使用Python-Markdown庫將Markdown文本轉(zhuǎn)換為HTML,需要的可以參考下2025-03-03

