python遞歸函數(shù)練習(xí) python遞歸算法40例

Python 實現(xiàn)遞歸

一、使用遞歸的背景

目前創(chuàng)新互聯(lián)公司已為1000多家的企業(yè)提供了網(wǎng)站建設(shè)、域名、雅安服務(wù)器托管、網(wǎng)站托管維護(hù)、企業(yè)網(wǎng)站設(shè)計、肅北網(wǎng)站維護(hù)等服務(wù),公司將堅持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。

先來看一個??接口結(jié)構(gòu):

這個孩子,他是一個列表,下面有6個元素

展開children下第一個元素[0]看看:

發(fā)現(xiàn)[0]除了包含一些字段信息,還包含了 children 這個字段(喜當(dāng)?shù)?,同時這個children下包含了2個元素:

展開他的第一個元素,不出所料,也含有children字段(人均有娃)

可以理解為children是個對象,他包含了一些屬性,特別的是其中有一個屬性與父級children是一模一樣的,他包含父級children所有的屬性。

比如每個children都包含了一個name字段,我們要拿到所有children里name字段的值,這時候就要用到遞歸啦~

二、find_children.py

拆分理解:

1.首先import requests庫,用它請求并獲取接口返回的數(shù)據(jù)

2.若children以上還有很多層級,可以縮小數(shù)據(jù)范圍,定位到children的上一層級

3.來看看定義的函數(shù)

我們的函數(shù)調(diào)用:find_children(node_f, 'children')

其中,node_f:json字段

??? children:遞歸對象

?以下這段是實現(xiàn)遞歸的核心:

?? if items['children']:

?items['children']不為None,表示該元素下的children字段還有子類數(shù)據(jù)值,此時滿足if條件,可理解為 if 1。

?items['children']為None,表示該元素下children值為None,沒有后續(xù)可遞歸值,此時不滿足if條件,可理解為 if 0,不會再執(zhí)行if下的語句(不會再遞歸)。

至此,每一層級中children的name以及下一層級children的name就都取出來了

希望到這里能幫助大家理解遞歸的思路,以后根據(jù)這個模板直接套用就行

(晚安啦~)

源碼參考:

python如何用遞歸函數(shù)求1+2+3+4+5的值

python用遞歸函數(shù)求1+2+3+4+5的值的方法:

1、寫出臨界條件

2、找這一次和上一次的關(guān)系

3、假設(shè)當(dāng)前函數(shù)已經(jīng)能用,調(diào)用自身計算上一次的結(jié)果,再求出本次的結(jié)果

代碼實現(xiàn)如下:

python遞歸函數(shù)

def Sum(m): #函數(shù)返回兩個值:遞歸次數(shù),所求的值 if m==1:return 1,m return 1+Sum(m-1)[0],m+Sum(m-1)[1]cishu=Sum(10)[0] print cishu def Sum(m,n=1): ... if m==1:return n,m ... return n,m+Sum(m-1,n+1)[1] print Sum(10)[0] 10 print Sum(5)[0] 5

網(wǎng)頁名稱:python遞歸函數(shù)練習(xí) python遞歸算法40例
URL鏈接:http://www.muchs.cn/article6/doeehog.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供企業(yè)網(wǎng)站制作、網(wǎng)頁設(shè)計公司、、企業(yè)建站、品牌網(wǎng)站制作、軟件開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站托管運營