亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

Python3基礎(chǔ)教程之遞歸函數(shù)簡(jiǎn)單示例

系統(tǒng) 2119 0

概述

遞歸函數(shù)即直接或間接調(diào)用自身的函數(shù),且遞歸過(guò)程中必須有一個(gè)明確的遞歸結(jié)束條件,稱(chēng)為遞歸出口。遞歸極其強(qiáng)大一點(diǎn)就是能夠遍歷任意的,不可預(yù)知的程序的結(jié)構(gòu),比如遍歷復(fù)雜的嵌套列表。

遞歸求和

我們可以利用遞歸函數(shù)實(shí)現(xiàn)一個(gè)Python內(nèi)置函數(shù)sum()的遞歸版。

            
# 遞歸
def d_sum(L):
  if not L:
    return 0
  else:
    return L[0] + d_sum(L[1:])

sum_l = d_sum(range(10))
print(sum_l)
          

示例結(jié)果

45

該遞歸函數(shù)怎么實(shí)現(xiàn)列表元素相加的呢? 我們知道函數(shù)是有本地作用域的,對(duì)函數(shù)調(diào)用的每一個(gè)打開(kāi)的時(shí)候,在運(yùn)行時(shí)調(diào)用堆棧上都有自己的一個(gè)本地作用域的副本,即L在每個(gè)層級(jí)都是不同的,比如我們可以通過(guò)每次調(diào)用時(shí)添加一個(gè)打印語(yǔ)句,更加直觀展示每個(gè)層級(jí)L的情況

            
# 遞歸
def d_sum(L):
  # 打印該層級(jí)L
  print(L)
  if not L:
    return 0
  else:
    return L[0] + d_sum(L[1:])
# 構(gòu)建 0-10 數(shù)字元素列表
L = [i for i in range(10)]
sum_l = d_sum(L)
print(sum_l)
          

[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
[1, 2, 3, 4, 5, 6, 7, 8, 9]
[2, 3, 4, 5, 6, 7, 8, 9]
[3, 4, 5, 6, 7, 8, 9]
[4, 5, 6, 7, 8, 9]
[5, 6, 7, 8, 9]
[6, 7, 8, 9]
[7, 8, 9]
[8, 9]
[9]
[]
45

處理任意結(jié)構(gòu)

比如我們可以利用遞歸計(jì)算一個(gè)嵌套的子列表結(jié)構(gòu)中所有數(shù)字的總和

            
def dd_sum(L):
  tot = 0
  for x in L:
    if not isinstance(x, list):
      tot += x
    else:
      tot += dd_sum(x)
  return tot

# 嵌套列表
L = [1,[2,3],[4,[5,6,7],8],9]
sum_l = dd_sum(L)
print(sum_l)
          

示例結(jié)果:

45

這種處理方式看似復(fù)雜,我們可能更多會(huì)利用循環(huán)語(yǔ)句替代,但是使用遞歸函數(shù)邏輯簡(jiǎn)單清晰,這是使用的一大優(yōu)點(diǎn)。

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫(xiě)作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫(xiě)作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長(zhǎng)會(huì)非常 感謝您的哦!!!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 国产精品久久久久免费视频 | 亚洲一区中文字幕在线观看 | 九九九九热精品免费视频 | 亚洲国产成人在线观看 | 日韩免费一级毛片 | 加勒比精品久久一区二区三区 | 久久er热在这里只有精品85 | 国产第一综合另类色区奇米 | 成人国产精品免费视频不卡 | 国产精品一区二区久久沈樵 | 色就色综合 | 校园春色男人天堂 | 日本伊人久久 | www.四虎影视.com | 日本粉嫩毛片视频 | 日日操夜夜操视频 | 乱人伦视频69 | 精品免费一区二区三区 | 国产自产拍精品视频免费看 | 同性女女黄h片在线播放 | 欧洲亚洲综合一区二区三区 | 人人操天天射 | 国产欧美一区二区三区精品 | 久热只有精品 | 久久精品日日躁夜夜躁欧美 | 国产区二区 | 国产精品久久影院 | 韩国一级理黄论片 | 国产日韩久久久久69影院 | 在线a毛片免费视频观看 | 欧美三级一区二区 | 国产亚洲精品sese在线播放 | 亚洲精品欧美精品日韩精品 | 操综合| 老司机激情影院 | 青青青爽视频在线观看入口 | 国产精品人成 | 国产精品.com | 国产精品u任我爽爆在线播放 | 麻豆精品| 亚洲国产精品悠悠久久琪琪 |