当前位置: 首页 > news >正文

7️⃣ 递归函数

在函数内部调用自身的函数,就是递归函数。递归是编程中一个非常常用、也非常直观的逻辑结构,用于解决可拆解为相似子问题的问题。

    • 一、方法速查表(含示例)
    • 二、 递归计算阶乘
    • 三、 尾递归实现(理论优化)
    • 四、 递归应用:汉诺塔
    • 五、使用递归的注意事项
    • 六、小结

一、方法速查表(含示例)

方法/概念示例代码片段说明
定义递归函数def fact(n): return 1 if n==1 else n*fact(n-1)用于计算阶乘
终止条件if n == 1: return 1防止无限递归
调用自身return n * fact(n-1)递归核心调用
尾递归优化写法fact_iter(num-1, num*product)避免嵌套表达式,理论上防栈溢出
判断栈溢出RuntimeError: maximum recursion depth exceeded递归层数太多时报错

二、 递归计算阶乘

def fact(n):if n == 1:return 1return n * fact(n - 1)print(fact(5))  # 输出 120

过程解析(计算 fact(5)):

fact(5)
=> 5 * fact(4)
=> 5 * (4 * fact(3))
=> ...
=> 5 * 4 * 3 * 2 * 1 = 120

三、 尾递归实现(理论优化)

def fact(n):return fact_iter(n, 1)def fact_iter(num, product):if num == 1:return productreturn fact_iter(num - 1, num * product)

⚠️ 注意:Python 并不会优化尾递归,这种写法在 Python 中仍然可能栈溢出。


四、 递归应用:汉诺塔

def move(n, a, b, c):if n == 1:print(a, '-->', c)else:move(n - 1, a, c, b)print(a, '-->', c)move(n - 1, b, a, c)move(3, 'A', 'B', 'C')

输出:

A --> C
A --> B
C --> B
A --> C
B --> A
B --> C
A --> C

🧵 别纠结中间过程
在这里插入图片描述


五、使用递归的注意事项

  • ✅ 优点:逻辑清晰、结构简洁,适合处理分治类问题。
  • ⚠️ 缺点:层数过深会导致 栈溢出(Python 默认最大递归深度约为 1000)。

📌 尾递归并不能避免栈溢出(在 Python 中),因为 Python 没有进行尾递归优化。


六、小结

  • 递归适合分解重复结构的问题(如阶乘、树结构、汉诺塔)。
  • 所有递归都可以转换为循环,但递归写法通常更清晰。
  • 尾递归在理论上可优化栈使用,但在 Python 中无实际效果。
  • 使用递归时,务必写好终止条件,防止死递归导致崩溃。
http://www.dtcms.com/a/299478.html

相关文章:

  • 【AcWing 835题解】滑动窗口
  • 数据结构 双向链表
  • greenhills编译出错问题
  • C++学习之深入学习模板(进阶)
  • SAPUI5 树形表格TreeTable示例
  • Spring AI(14)——文本分块优化
  • java之23种设计模式
  • 设计模式:Memento 模式详解
  • 简单实现支付密码的页面及输入效果
  • 面条式代码(Spaghetti Code)
  • Java高级之基于Java Attach与Byte-Buddy实现SQL语句增强
  • JWT安全机制与最佳实践详解
  • Linux 系统调用详解:操作文件的常用系统调用
  • Vulnhub jangow-01-1.0.1靶机渗透攻略详解
  • 自定义定时任务功能详解
  • MySQL 表的约束
  • 【面板数据】中国A股上市公司制造业智能制造数据集(1992-2024年)
  • 基于图神经网络的星间路由与计算卸载强化学习算法设计与实现
  • java实现一个方法,isTure则程序继续往下,为false则return的链式写法
  • 零基础学习性能测试第三章:jmeter线程组组合
  • LeetCode|Day26|191. 位 1 的个数|Python刷题笔记
  • Java学习|黑马笔记|Day23】网络编程、反射、动态代理
  • AI+预测3D新模型百十个定位预测+胆码预测+去和尾2025年7月26日第150弹
  • 在Power Automate Desktop中执行PowerShell获取SharePoint online某个文件夹的用户权限列表
  • SAP ABAP的数据通过调用泛微Restful API同步数据到OA建模表
  • 学习日志19 python
  • pytest中的rerunfailures的插件(失败重试)
  • 在 Scintilla 中为 Squirrel 语言设置语法解析器的方法
  • 【Kubernetes】使用StatefulSet进行的资源调度,扩缩容,更改配置到版本回滚,三种配置更新方式
  • c#中让图片显示清晰