python防止棧溢出的實(shí)例講解
1、說明
使用遞歸函數(shù)的優(yōu)點(diǎn)是邏輯簡單清晰,缺點(diǎn)是過深的調(diào)用會導(dǎo)致棧溢出。
解決遞歸調(diào)用棧溢出的方法是通過尾遞歸優(yōu)化,事實(shí)上尾遞歸和循環(huán)的效果是一樣的,所以,把循環(huán)看成是一種特殊的尾遞歸函數(shù)也是可以的。
2、實(shí)例
def fact(n): return fact_iter(n, 1) def fact_iter(num, product): if num == 1: return product return fact_iter(num - 1, num * product) # fact(5)的調(diào)用過程 ===> fact_iter(5, 1) ===> fact_iter(4, 5) ===> fact_iter(3, 20) ===> fact_iter(2, 60) ===> fact_iter(1, 120) ===> 120
知識點(diǎn)擴(kuò)展:
棧溢出
在計(jì)算機(jī)中,函數(shù)調(diào)用是通過棧(stack)這種數(shù)據(jù)結(jié)構(gòu)實(shí)現(xiàn)的,每當(dāng)進(jìn)入一個(gè)函數(shù)調(diào)用,棧就會加一層棧幀,每當(dāng)函數(shù)返回,棧就會減一層棧幀。由于棧的大小不是無限的,所以,遞歸調(diào)用的次數(shù)過多,會導(dǎo)致棧溢出??梢栽囋噁act(1000):
>>> fact(1000) Traceback (most recent call last): File "<stdin>", line 1, in <module> File "<stdin>", line 4, in fact ... File "<stdin>", line 4, in fact RuntimeError: maximum recursion depth exceeded
到此這篇關(guān)于python防止棧溢出的實(shí)例講解的文章就介紹到這了,更多相關(guān)python如何防止棧溢出內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- 詳解python數(shù)據(jù)結(jié)構(gòu)之棧stack
- python中實(shí)現(xiàn)棧的三種方法
- python全棧開發(fā)語法總結(jié)
- Python可以實(shí)現(xiàn)棧的結(jié)構(gòu)嗎
- Python捕獲異常堆棧信息的幾種方法(小結(jié))
- 使用Python將Exception異常錯(cuò)誤堆棧信息寫入日志文件
- Python實(shí)現(xiàn)棧的方法詳解【基于數(shù)組和單鏈表兩種方法】
- Python棧的實(shí)現(xiàn)方法示例【列表、單鏈表】
- python實(shí)現(xiàn)異常信息堆棧輸出到日志文件
- Python中棧的詳細(xì)介紹
相關(guān)文章
python Selenium實(shí)現(xiàn)付費(fèi)音樂批量下載的實(shí)現(xiàn)方法
這篇文章主要介紹了python Selenium實(shí)現(xiàn)付費(fèi)音樂批量下載的實(shí)現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-01-01Windows系統(tǒng)配置python腳本開機(jī)啟動的3種方法分享
這篇文章主要介紹了Windows系統(tǒng)配置python腳本開機(jī)啟動的3種方法分享,本文講解了開始菜單啟動項(xiàng)實(shí)現(xiàn)、開機(jī)腳本、通過一個(gè)服務(wù)調(diào)用該腳本三種方法,需要的朋友可以參考下2015-03-03python使用writerows寫csv文件產(chǎn)生多余空行的處理方法
這篇文章主要介紹了python使用writerows寫csv文件產(chǎn)生多余空行的處理方法,需要的朋友可以參考下2019-08-08