python數(shù)據(jù)結(jié)構(gòu)之遞歸方法講解
今天我們來(lái)學(xué)習(xí)python中最為重要的內(nèi)容之遞歸,對(duì)以往內(nèi)容感興趣的同學(xué)可以查看下面:
python數(shù)據(jù)類型: python數(shù)據(jù)結(jié)構(gòu):數(shù)據(jù)類型.
python的輸入輸出: python數(shù)據(jù)結(jié)構(gòu)之輸入輸出、控制和異常.
python面向?qū)ο? python數(shù)據(jù)結(jié)構(gòu)之面向?qū)ο?
python算法分析: python數(shù)據(jù)結(jié)構(gòu)算法分析.
python數(shù)據(jù)結(jié)構(gòu)之棧、隊(duì)列和雙端隊(duì)列
遞歸是在進(jìn)行重復(fù)性工作中經(jīng)??嫉降膯?wèn)題,非常值得學(xué)習(xí)。
1.遞歸概念
遞歸是解決問(wèn)題的一種方法,它將問(wèn)題不斷地分成更小的子問(wèn)題,直到子問(wèn)題可以用普通的方法解決。通常情況下,遞歸會(huì)使用一個(gè)不停調(diào)用自己的函數(shù)。盡管表面上看起來(lái)很普通,但是遞歸可以幫助我們寫出非常優(yōu)雅的解決方案。對(duì)于某些問(wèn)題,如果不用遞歸,就很難解決。
上面的話很難理解,我們用一個(gè)例子來(lái)說(shuō)明:我們需要求解一個(gè)數(shù)組的所有數(shù)值之和。
#用for循環(huán)的簡(jiǎn)單函數(shù) def getsum(numlist): a=0 for i in numlist: a=i+a return a
結(jié)果如下:
如果暫時(shí)沒(méi)有 while
循環(huán)和 for 循環(huán)。應(yīng)該如何計(jì)算結(jié)果呢? 這個(gè)時(shí)候就需要想到我們計(jì)算加法的時(shí)候,是接受2個(gè)參數(shù)的函數(shù),根據(jù)這個(gè)思想,我們將求一列數(shù)之和重新定義成求數(shù)字對(duì)之和。
注:最內(nèi)層的括號(hào)對(duì)(7 + 9)不用 循環(huán)或者其他特殊語(yǔ)法結(jié)構(gòu)就能直接求解。
擬代碼表示
#first(list)返回列表中的第一個(gè)元素,rest(list)則返回其余元素。用 Python 可以輕松地實(shí)現(xiàn)這個(gè)等式, getsum(list)=first(list)+getsum(rest(list))
代碼表示:
#這是一個(gè)遞歸小案例,這個(gè)函數(shù)在函數(shù)內(nèi)部自己調(diào)用了自listsum(numlist[1:]) def listsum(numlist): if len(numlist)==1:#當(dāng)數(shù)組的長(zhǎng)度為1時(shí),代表是數(shù)組是一個(gè)數(shù)了 return numlist[0] else: return numlist[0] + listsum(numlist[1:])#第一個(gè)數(shù)加上后面的數(shù),這里自己調(diào)用了自己,是數(shù)組不斷遞歸的條件
在這一段代碼中,有兩個(gè)重要的思想值得探討。首先,第 2 行檢查列表是否只包含一個(gè)元素。 這個(gè)檢查非常重要,同時(shí)也是該函數(shù)的退出語(yǔ)句。對(duì)于長(zhǎng)度為 1 的列表,其元素之和就是列表中的數(shù)。其次,listsum 函數(shù)在第 5 行調(diào)用了自己!這就是我們將 listsum
稱為遞歸函數(shù)的原因——遞歸函數(shù)會(huì)調(diào)用自己。
演示一下相加過(guò)程
2. 遞歸三原則
遞歸算法有三個(gè)重要的原則:
- 遞歸算法必須有停止條件
- 遞歸算法必須改變其狀態(tài)并向停止條件靠近
- 遞歸算法必須遞歸地調(diào)用自己
讓我們看看我們第一個(gè)案例是怎么實(shí)現(xiàn)這個(gè)部分的:
len(numlist)==1
用來(lái)判斷停止條件numlist[1:]
代表問(wèn)題的數(shù)據(jù)以某種方式變得更小return numlist[0] + listsum(numlist[1:])
代表遞歸地調(diào)用自己
遞歸的邏輯并不是循環(huán),而是將問(wèn)題分解成更小、更容易解決的子問(wèn)題。
2.1 實(shí)現(xiàn)任意進(jìn)制的數(shù)據(jù)轉(zhuǎn)換
下面展示一下將10進(jìn)制的29轉(zhuǎn)換為2進(jìn)制數(shù)的方法,按照這個(gè)方法,可以將10進(jìn)制轉(zhuǎn)化為任意進(jìn)制的數(shù)。
這里我們用遞歸來(lái)實(shí)現(xiàn)2~16進(jìn)制數(shù)的轉(zhuǎn)換
#n代表要轉(zhuǎn)化的10進(jìn)制數(shù),base代表你要實(shí)現(xiàn)的多少進(jìn)制的數(shù) def toStr(n, base): convertString = "0123456789ABCDEF"#取對(duì)應(yīng)位置的字符 if n < base:#如果10進(jìn)制數(shù)小于你所轉(zhuǎn)換的進(jìn)制數(shù)位數(shù),則直接選擇字符 return convertString[n] else:#遞歸核心,n//base獲取結(jié)果,然后進(jìn)行遞歸 return toStr(n//base, base) + convertString[n%base]
到此這篇關(guān)于python數(shù)據(jù)結(jié)構(gòu)之遞歸方法講解的文章就介紹到這了,更多相關(guān)python遞歸內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
python網(wǎng)絡(luò)編程學(xué)習(xí)筆記(三):socket網(wǎng)絡(luò)服務(wù)器
服務(wù)器和客戶端程序很類似,上節(jié)學(xué)習(xí)了客戶端程序,這一節(jié)將仔細(xì)學(xué)習(xí)一下利用socket建立TCP服務(wù)器和UDP服務(wù)器2014-06-06pycharm設(shè)置默認(rèn)的UTF-8編碼模式的方法詳解
這篇文章主要介紹了pycharm設(shè)置默認(rèn)的UTF-8編碼模式,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-06-06python實(shí)現(xiàn)監(jiān)控指定進(jìn)程的cpu和內(nèi)存使用率
這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)監(jiān)控指定進(jìn)程的cpu和內(nèi)存使用率,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01Python閉包之返回函數(shù)的函數(shù)用法示例
這篇文章主要介紹了 Python閉包之返回函數(shù)的函數(shù)用法示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-01-01Python庫(kù)urllib與urllib2主要區(qū)別分析
這篇文章主要介紹了Python庫(kù)urllib與urllib2主要區(qū)別,需要的朋友可以參考下2014-07-07PyTorch中 tensor.detach() 和 tensor.data 的區(qū)別詳解
今天小編就為大家分享一篇PyTorch中 tensor.detach() 和 tensor.data 的區(qū)別詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-01-01