python防止栈溢出的解决

说明

1、使用递归函数的优点是逻辑简单明了,缺点是调用过深会导致栈溢出。

2、递归调用栈溢出的方法是栈溢出问题,实际上尾递归与循环效果相同。

3、将循环视为一种特殊的尾递归函数也是可以的。

实例

deffact(n):
returnfact_iter(n,1)

deffact_iter(num,product):
ifnum==1:
returnproduct
returnfact_iter(num-1,num*product)

#fact(5)的调用过程
===>fact_iter(5,1)
===>fact_iter(4,5)
===>fact_iter(3,20)
===>fact_iter(2,60)
===>fact_iter(1,120)
===>120

以上就是python防止栈溢出的方法,希望对大家有所帮助。更多Python学习指路:Python基础教程

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。