国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術(shù)文章
文章詳情頁

python防止棧溢出的實(shí)例講解

瀏覽:7日期:2022-06-19 13:11:09
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)入一個函數(shù)調(diào)用,棧就會加一層棧幀,每當(dāng)函數(shù)返回,棧就會減一層棧幀。由于棧的大小不是無限的,所以,遞歸調(diào)用的次數(shù)過多,會導(dǎo)致棧溢出。可以試試fact(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 factRuntimeError: maximum recursion depth exceeded

到此這篇關(guān)于python防止棧溢出的實(shí)例講解的文章就介紹到這了,更多相關(guān)python如何防止棧溢出內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 彰化县| 乐山市| 东至县| 宣汉县| 连山| 湟源县| 辰溪县| 富裕县| 永川市| 宜春市| 扎囊县| 句容市| 永泰县| 济宁市| 乳源| 石泉县| 延长县| 施秉县| 沅陵县| 漠河县| 武川县| 洛扎县| 永康市| 安岳县| 营口市| 从化市| 岗巴县| 土默特右旗| 崇仁县| 通山县| 宜州市| 白银市| 阜阳市| 伊春市| 文成县| 时尚| 顺平县| 鄂托克前旗| 土默特左旗| 花莲市| 蓬安县|