欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

Python3之遞歸函數(shù)簡單示例

系統(tǒng) 1884 0

概述

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

遞歸求和

我們可以利用遞歸函數(shù)實現(xiàn)一個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ù)怎么實現(xiàn)列表元素相加的呢? 我們知道函數(shù)是有本地作用域的,對函數(shù)調(diào)用的每一個打開的時候,在運行時調(diào)用堆棧上都有自己的一個本地作用域的副本,即L在每個層級都是不同的,比如我們可以通過每次調(diào)用時添加一個打印語句,更加直觀展示每個層級L的情況

            
              
                # 遞歸
              
              
                def
              
              
                d_sum
              
              
                (
              
              L
              
                )
              
              
                :
              
              
                # 打印該層級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)

比如我們可以利用遞歸計算一個嵌套的子列表結(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

            
          

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


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

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

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

【本文對您有幫助就好】

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

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 91麻豆精品久久久久蜜臀 | 网友自拍视频在线 | 欧美日韩亚洲一区 | 日韩成人性视频 | 日本免费大片免费视频 | 欧美国产日韩在线 | 日本一区二区不卡 | 国产97色在线 | 亚洲 | 天天操夜夜夜 | 狠狠干2020 | 亚洲 欧美精品 | 日本高清一级片 | 精品一区二区三区四区 | 九九综合九九 | 99动漫| 欧美国产日韩在线观看 | 天天成人综合网 | 一级毛片特级毛片免费的 | 久久精品国产99国产精品澳门 | 美女吊逼 | 国产欧美日韩视频在线观看 | 亚洲狠狠干 | 一本伊大人香蕉久久网手机 | 无码日本亚洲一区久久精品 | 国产精品密蕾丝视频下载 | 久久精品国产一区二区电影 | 亚洲六月丁香色婷婷综合久久 | 久久精品免费观看 | 国产99视频在线 | 99久久精品国产毛片 | 韩国三级午夜理伦三级三 | 波多野吉衣一区 | 精品欧美一区二区三区在线 | 三级国产精品一区二区 | 久久久久久久久久久久久久久久久久久 | 久久久精品视频免费看 | 欧美成人做性视频在线播放 | 欧美高清视频一区 | 色爱区综合 | 国产欧美日韩在线观看 | 538prom国产在线视频一区 |