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

Python3之遞歸函數簡單示例

系統 2021 0

概述

遞歸函數即直接或間接調用自身的函數,且遞歸過程中必須有一個明確的遞歸結束條件,稱為遞歸出口。遞歸極其強大一點就是能夠遍歷任意的,不可預知的程序的結構,比如遍歷復雜的嵌套列表。

遞歸求和

我們可以利用遞歸函數實現一個Python內置函數 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
              
                )
              
            
          

示例結果

            
              45

            
          

該遞歸函數怎么實現列表元素相加的呢? 我們知道函數是有本地作用域的,對函數調用的每一個打開的時候,在運行時調用堆棧上都有自己的一個本地作用域的副本,即L在每個層級都是不同的,比如我們可以通過每次調用時添加一個打印語句,更加直觀展示每個層級L的情況

            
              
                # 遞歸
              
              
                def
              
              
                d_sum
              
              
                (
              
              L
              
                )
              
              
                :
              
              
                # 打印該層級L
              
              
                print
              
              
                (
              
              L
              
                )
              
              
                if
              
              
                not
              
               L
              
                :
              
              
                return
              
              
                0
              
              
                else
              
              
                :
              
              
                return
              
               L
              
                [
              
              
                0
              
              
                ]
              
              
                +
              
               d_sum
              
                (
              
              L
              
                [
              
              
                1
              
              
                :
              
              
                ]
              
              
                )
              
              
                # 構建 0-10 數字元素列表
              
              
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

            
          

處理任意結構

比如我們可以利用遞歸計算一個嵌套的子列表結構中所有數字的總和

            
              
                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
              
                )
              
            
          

示例結果:

            
              45

            
          

這種處理方式看似復雜,我們可能更多會利用循環語句替代,但是使用遞歸函數邏輯簡單清晰,這是使用的一大優點。


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

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

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦?。?!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 亚洲综合色丁香麻豆 | 国产精品福利视频一区二区三区 | 九天玄帝诀免费完整观看 | 五月婷婷丁香在线视频 | 韩国高清不卡一区二区 | 亚洲精品久久九九热 | 久久精品综合视频 | 午夜影院操 | 久久伊人久久亚洲综合 | 成人一区二区免费中文字幕 | 国产精品视频观看 | 亚洲欧美色综合一区二区在线 | 激情五月婷婷久久 | 一区国严二区亚洲三区 | 国产福利视频奶水在线 | 在线精品日韩一区二区三区 | 免费的拍拍视频在线观看 | 国产亚洲一区在线 | 91最新视频在线观看 | 特级全黄一级毛片免费 | jizzjiz熟丰满老妇日本 | 久久网在线 | 人人爱操| 99久久99久久 | 中文字幕一区二区三区亚洲精品 | 久久青草免费线观最新 | 日本一区精品 | 久久精品免看国产 | 欧美性猛交99久久久久99 | 国产一级特黄a大片免费 | 国产精品午夜高清在线观看 | 男女黄网站 | 四虎在线观看视频 | a毛片在线免费观看 | 99久久在线 | 男人天堂一区 | 亚洲国产精品热久久 | 91久久亚洲精品国产一区二区 | 手机看片久久国产免费不卡 | ass最极品女人下部pic | 牛牛影视在线观看片免费 |