递归调用过深或栈溢出:Python递归示例及其风险

原创 青旅半醒 2025-02-26 11:24 44阅读 0赞

递归是一种编程技术,其中函数通过调用自身来解决问题。然而,如果递归调用过深,或者递归过程中没有正确地更新栈信息(如在C++中使用std::stack),都可能导致栈溢出。

下面是一个简单的Python递归示例,计算阶乘:

  1. def factorial(n):
  2. if n == 0 or n == 1:
  3. return 1
  4. else:
  5. return n * factorial(n-1)
  6. print(factorial(5)) # 这将导致栈溢出

在这个例子中,如果我们试图计算factorial(6),递归调用的深度将会非常大,超过了Python默认的最大递归深度,从而引发栈溢出错误。

文章版权声明:注明蒲公英云原创文章,转载或复制请以超链接形式并注明出处。

发表评论

表情:
评论列表 (有 0 条评论,44人围观)

还没有评论,来说两句吧...

相关阅读