python遞歸函數(shù)調(diào)用,python中函數(shù)的遞歸調(diào)用

Python算法-爬樓梯與遞歸函數(shù)

可以看出來的是,該題可以用斐波那契數(shù)列解決。

成都創(chuàng)新互聯(lián)是一家專業(yè)提供寶山企業(yè)網(wǎng)站建設(shè),專注與成都做網(wǎng)站、成都網(wǎng)站制作、成都外貿(mào)網(wǎng)站建設(shè)、H5建站、小程序制作等業(yè)務。10年已為寶山眾多企業(yè)、政府機構(gòu)等服務。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站建設(shè)公司優(yōu)惠進行中。

樓梯一共有n層,每次只能走1層或者2層,而要走到最終的n層。不是從n-1或者就是n-2來的。

F(1) = 1

F(2) = 2

F(n) = F(n-1) + F(n-2) (n=3)

這是遞歸寫法,但是會導致棧溢出。在計算機中,函數(shù)的調(diào)用是通過棧進行實現(xiàn)的,如果遞歸調(diào)用的次數(shù)過多,就會導致棧溢出。

針對這種情況就要使用方法二,改成非遞歸函數(shù)。

將遞歸進行改寫,實現(xiàn)循環(huán)就不會導致棧溢出

python函數(shù)高級

一、函數(shù)的定義

函數(shù)是指將一組語句的集合通過一個名字(函數(shù)名)封裝起來,想要執(zhí)行這個函數(shù),只需要調(diào)用函數(shù)名即可

特性:

減少重復代碼

使程序變得可擴展

使程序變得易維護

二、函數(shù)的參數(shù)

2.1、形參和實參數(shù)

形參,調(diào)用時才會存在的值

實慘,實際存在的值

2.2、默認參數(shù)

定義:當不輸入?yún)?shù)值會有一個默認的值,默認參數(shù)要放到最后

2.3、 關(guān)鍵參數(shù)

定義: 正常情況下,給函數(shù)傳參數(shù)要安裝順序,不想按順序可以用關(guān)鍵參數(shù),只需要指定參數(shù)名即可,(指定了參數(shù)名的就叫關(guān)鍵參數(shù)),但是要求是關(guān)鍵參數(shù)必須放在位置參數(shù)(以位置順序確定對應的參數(shù))之后

2.4、非固定參數(shù)

定義: 如你的函數(shù)在傳入?yún)?shù)時不確定需要傳入多少個參數(shù),就可以使用非固定參數(shù)

# 通過元組形式傳遞

# 通過列表形式傳遞

# 字典形式(通過k,value的方式傳遞)

# 通過變量的方式傳遞

三、函數(shù)的返回值

作用:

返回函數(shù)執(zhí)行結(jié)果,如果沒有設(shè)置,默認返回None

終止函數(shù)運行,函數(shù)遇到return終止函數(shù)

四、變量的作用域

全局變量和局部變量

在函數(shù)中定義的變量叫局部變量,在程序中一開始定義的變量叫全局變量

全局變量作用域整個程序,局部變量作用域是定義該變量的函數(shù)

當全局變量與局部變量同名是,在定義局部變量的函數(shù)內(nèi),局部變量起作用,其他地方全局變量起作用

同級的局部變量不能互相調(diào)用

想要函數(shù)里邊的變量設(shè)置成全局變量,可用global進行設(shè)置

五、特殊函數(shù)

5.1、嵌套函數(shù)

定義: 嵌套函數(shù)顧名思義就是在函數(shù)里邊再嵌套一層函數(shù)

提示 在嵌套函數(shù)里邊調(diào)用變量是從里往外依次調(diào)用,意思就是如果需要調(diào)用的變量在當前層沒有就會去外層去調(diào)用,依次內(nèi)推

匿名函數(shù)

基于Lambda定義的函數(shù)格式為: lambda 參數(shù):函數(shù)體

參數(shù),支持任意參數(shù)。

匿名函數(shù)適用于簡單的業(yè)務處理,可以快速并簡單的創(chuàng)建函數(shù)。

# 與三元運算結(jié)合

5.3、高階函數(shù)

定義:變量可以指向函數(shù),函數(shù)的參數(shù)可以接收變量,那么一個函數(shù)就可以接收另一個函數(shù)作為參數(shù),這種函數(shù)稱之為高階函數(shù) 只需要滿足一下任意一個條件,即是高階函數(shù)

接收一個或多個函數(shù)作為輸入

return返回另一個函數(shù)

5.4、遞歸函數(shù)

定義:一個函數(shù)可以調(diào)用其他函數(shù),如果一個函數(shù)調(diào)用自己本身,這個函數(shù)就稱為遞歸函數(shù)

在默認情況下Python最多能遞歸1000次,(這樣設(shè)計師是為了防止被內(nèi)存被撐死)可以通過sys.setrecursionlimit(1500)進行修改

遞歸實現(xiàn)過程是先一層一層的進,然后在一層一層的出來

必須有一個明確的條件結(jié)束,要不然就是一個死循環(huán)了

每次進入更深層次,問題規(guī)模都應該有所減少

遞歸執(zhí)行效率不高,遞歸層次過多會導致站溢出

# 計算4的階乘 4x3x2x1

# 打印數(shù)字從1-100

5.5、閉包現(xiàn)象

定義:內(nèi)層函數(shù)調(diào)用外層函數(shù)的變量,并且內(nèi)存函數(shù)被返回到外邊去了

閉包的意義:返回的函數(shù)對象,不僅僅是一個函數(shù)對象,在該函數(shù)外還包裹了一層作用域,這使得,該函數(shù)無論在何處調(diào)用,優(yōu)先使用自己外層包裹的作用域

利用遞歸函數(shù)求斐波那契值python版

首先我們要了解一下什么是遞歸。

遞歸法,遞歸法就是利用上一個或者上幾個狀態(tài)來求取當前狀態(tài)的值(個人看法)。也可以說成函數(shù)自己調(diào)用自己的一種解決問題的策略。因此遞歸法通常是依托函數(shù)來實現(xiàn)的,遞歸函數(shù)總是會有一個出口,我們在解決遞歸問題時,只需要找出遞歸的關(guān)系式以及遞歸函數(shù)的出口(這兩個可以說是遞歸函數(shù)的核心了)。下面我將在這里舉求斐波那契值的例子帶領(lǐng)著大家具體的實踐一下遞歸法。

很顯然遞歸函數(shù)的遞推式是:fib(n) = fib(n-1)+fib(n-2)。

遞歸函數(shù)的出口是當n為1時返回1,當n為0時返回0。

最后遞歸函數(shù)的核心代碼就可以寫出了:

然后總的代碼就是:

具體思路如下:

語句 return fib(n-1)+fib(n-2)的意思就是向前求斐波那契值,直到n-1=1,n-2=0

因為只有第1個和第0個斐波那契值是確定的

例:

當n=3時

第一次調(diào)用函數(shù)fib會執(zhí)行第三條語句(因為n1)這樣求回返回fib(2)+fib(1)

第二次調(diào)用函數(shù)時,因為21所有會返回fib(1)+fib(0);因為1不大于1,所以調(diào)用函數(shù)時

會執(zhí)行第二條語句返回1值。

第三次調(diào)用函數(shù),會執(zhí)行第一和第二條語句,依次返回0和1從而求得fib(2)

fib(3)=fib(2)+fib(1)

fib(2)=fib(1)+fib(0)

即fib(3)=fib(1)+fib(0)+fib(1)=2*fib(1)+fib(0)

文章名稱:python遞歸函數(shù)調(diào)用,python中函數(shù)的遞歸調(diào)用
鏈接URL:http://muchs.cn/article16/hcjsgg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供虛擬主機、網(wǎng)站營銷定制開發(fā)、微信小程序建站公司、網(wǎng)站策劃

廣告

聲明:本網(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)站托管運營