函数递归
1.python基础之注释2.python语言学习路线(基础)3.python源码结构4.python发展史及python应用场景5.变量6.bug及debug7.常见数据类型及其转换8.字符串格式化9.转义符10.字符串在货币、日期、精度的处理11.字符编解码12.字符编解码及其相互转换13.内置函数-help-帮助文档14.内置函数print-输出15.内置函数input16.运算符17.int的缓存策略(特别容易混)18.判断语句19.random模块20.判断语句+ random的应用-剪刀石头布游戏21.三元运算符(if else的简写)22.循环语句-while23.循环语句-while-练习题24.循环语句for循环25.循环语句 + else26.字符串类str27.正则在字符串中的简单应用28.列表(List)29.列表list的sort方法的坑30.列表综合应用-8个教室随机分配到3个教室31.元组32.自动组包 & 自动解包33.字典34.集合35.公共操作36.公共操作-推导式(集合、列表、字典)37.函数定义、调用、闭包38.拆包和交换变量值39.函数的变量作用域、返回值、参数
40.函数递归
41.匿名函数(lambda表达式)0142.内置函数abs43.内置函数round44.内置函数abs0245.高阶函数46.内置高阶函数map47.内置高阶函数reduce48.内置函数reduce49.学生管理系统-函数&循环&运算符综合练习50.文件操作之语法51.文件操作2-最佳实践52.文件操作之seek53.文件及文件夹操作54.面向对象基本概念55.面向对象之类、对象的定义56.添加和获取对象属性57.面向对象之魔法方法58.魔法函数 __repr__() 和 __str__()的区别59.魔法方法__len__60.魔法方法之__getitem__(self, key)、__setitem__(self, key, value) 和 __delitem__(self, key) 61.魔法方法之__iter__(self) && __next__(self)62.TypeError: iter() returned non-iterator of type 'MyIterable'63.魔法方法之__contains__()64.魔法方法之__call__65.魔法方法之__getattr__(), __setattr__(), 和 __delattr__66.__eq__(), __lt__(), 和 __gt__() 67.案例:烤地瓜68.案例:给房子置办家具69.继承70.继承之子类复用父类的属性、方法71.继承的分类72.MRO73.继承之子类重写父类同名属性和方法74.⼦类调⽤⽗类的同名⽅法和属性75.私有属性&&方法的定义&访问限制76.setter&getter方法访问私有属性77.__mro__属性78.python 面向对象3大特征详解79. 类属性和实例属性80.类属性和实例属性最佳实践81.类方法82.静态方法83.异常基础84.多组异常处理基础85.多组异常处理86.使用Python内置的错误信息87.捕获所有异常88.手动抛异常(raise)89.try-except-else-finally90.断言assert在异常中应用91.自定义异常类92.模块93.常见的5种模块导入94.模块的定位顺序95.__all__变量限制、明确导入范围96.包97.时间模块datetime98.多任务编程之并发、并行概念99.进程实现多任务(进程概念、单进程、多进程执行多任务)
1 ''' 2 函数的递归即函数调用自己 3 最佳实践: 4 1. 定义基本情况(终止条件): 递归函数应该始终包含一个或多个基本情况,即终止条件。这些基本情况描述了递归的结束条件,当满足这些条件时,递归将停止并返回结果。 5 2. 确保向基本情况收敛: 确保递归过程能够向基本情况无限接近,并最终收敛。如果递归没有向基本情况收敛,会导致无限递归,最终耗尽系统资源并引发错误。 6 3. 传递必要的参数: 在每次递归调用中,确保传递必要的参数以便递归正确执行。参数的值应该在递归的不同层级中改变以推进问题的解决。 7 4. 利用递归的结果: 在递归函数中合理利用递归的结果来构建最终的返回值。通常可以通过将递归结果与当前步骤的计算结果结合来获得所需的最终结果。 8 9 需要注意的坑: 10 1. 缺少或错误的终止条件: 如果没有正确定义基本情况(终止条件),递归将无法结束,导致无限递归并耗尽系统资源。确保定义了满足停止递归的基本情况。 11 2. 递归层数过多: Python默认递归深度有限。如果递归的层数超过了Python的递归限制,将引发RecursionError。如果需要处理大量的递归,可能需要考虑使用其他方法,如迭代或动态规划。 12 3. 重复计算: 在递归函数中,如果没有适当地利用递归的结果,可能会导致重复计算相同的值,从而浪费时间和资源。确保适当地利用递归的结果以避免重复计算。 13 4. 栈溢出: 递归函数在每次递归调用时都会创建一个新的函数帧并将其推入调用栈中。如果递归层数过多,可能导致调用栈溢出并引发RecursionError。确保递归不会达到系统的调用栈限制。 14 ''' 15 16 17 def factorial(n): 18 ''' n 表示要求的数的阶乘 ''' 19 if n == 1 or n == 0: 20 return 1 21 else: 22 return n * factorial(n - 1) # 返回结果 23 24 25 print(factorial(5))
# 需求:3以内数字累加和 3 + 2 + 1 = 6 # 6 = 3 + 2以内数字累加和 # 2以内数字累加和 = 2 + 1以内数字累加和 # 1以内数字累加和 = 1 # 出口 # 递归特点:函数内部自己调用自己;必须有出口 def sum_numbers(num): # 2. 出口 if num == 1: return 1 # 1. 当前数字 + 当前数字-1的累加和 return num + sum_numbers(num-1) result = sum_numbers(3) print(result) # 如果没有出口,报错:超出最大递归深度
在Python中,默认的递归深度限制是1000层。这意味着,如果递归调用的层数超过了1000层,将引发RecursionError异常。
可以通过sys.setrecursionlimit()
函数来更改默认的递归深度限制。例如,要将递归深度限制增加到2000层,可以使用以下代码:
1 import sys 2 3 sys.setrecursionlimit(2000)
需要注意的是,更改递归深度限制可能会影响程序的性能和内存使用情况。如果需要处理大量的递归或者递归深度很大,建议考虑其他解决方案,如迭代或动态规划,以避免栈溢出或性能问题。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!