前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【说站】python防止栈溢出的解决

【说站】python防止栈溢出的解决

作者头像
很酷的站长
发布2022-11-23 15:54:15
4040
发布2022-11-23 15:54:15
举报
文章被收录于专栏:站长的编程笔记

python防止栈溢出的解决

说明

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

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

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

实例

代码语言:javascript
复制
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)的调用过程
===> fact_iter(5, 1)
===> fact_iter(4, 5)
===> fact_iter(3, 20)
===> fact_iter(2, 60)
===> fact_iter(1, 120)
===> 120

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

本文教程操作环境:windows7系统、Python 3.9.1,DELL G3电脑。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • python防止栈溢出的解决
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档