一、初始遞歸
# 遞歸函數:在一個函數裡在呼叫這個函數本身。
遞歸的最大深度:998
正如你們剛剛看到的,遞歸函數如果不受到外力的阻止會一直執行下去。但是我們之前已經說過關於函數呼叫的問題,每一次函數呼叫都會產生一個屬於它自己的名稱空間,如果一直呼叫下去,就會造成名稱空間佔用太多記憶體的問題,於是python為了杜絕此類現象,強制的將遞歸層數控制在了997(只要997!你買不了吃虧,買不了上當...).
拿什麼來證明這個「998理論」呢?這裡我們可以做一個實驗:
def foo(n): print(n) n += 1 foo(n) foo(1)
由此我們可以看出,未報錯之前能看到的最大數字就是998.當然了,997是python為了我們程序的內存優化所設定的一個預設值,我們當然還可以透過一些手段去修改它:
import sys print(sys.setrecursionlimit(100000))
我們可以透過這種方式來修改遞歸的最大深度,剛剛我們將python允許的遞歸深度設定為了10w,至於實際可以達到的深度就取決於計算機的效能了。不過我們還是不建議修改這個預設的遞迴深度,因為如果用997層遞迴都沒有解決的問題要嘛是不適合用遞迴來解決要嘛是你程式碼寫的太爛了~~~
## 看到這裡,你可能會覺得遞歸也並不是多麼好的東西,不如while True好用呢!然而,江湖上流傳這這樣一句話叫做:人理解循環,神理解遞歸。所以你可別小看了遞歸函數,很多人被攔在大神的門檻外這麼多年,就是因為沒能領悟遞歸的真諦。而且之後我們學習的很多演算法都會跟遞歸有關係。來吧,只有學會了才有資本嫌棄!二、遞迴範例講解
這裡我們又要舉個例子來說明遞迴能做的事。 例一: 現在你們問我,alex老師多大了?我說我不告訴你,但alex比 egon 大兩歲。 你想知道alex多大,你是不是還要去問egon? egon說,我也不告訴你,但我比武sir大兩歲。 你又問武sir,武sir也不告訴你,他說他比太白大兩歲。 那你問太白,太白告訴你,他18了。 這時候你是不是就知道了? alex多大?金鑫 | #18 | |
---|---|---|
武sir | 20 | |
egon | 22 | |
alex | 24 |