Python学习总结——递归知识点

  • 本博客主要对函数递归相关知识点进行总结。
一、递归定义(Recursion)
  • 函数直接或者间接调用自身就是 递归
  • 递归需要有边界条件、递归前进段、递归返回段
  • 递归一定要有边界条件
  • 当边界条件不满足的时候,递归前进
  • 当边界条件满足的时候,递归返回
二、递归要求
  1. 递归一定要有退出条件,递归调用一定要执行到这个退出条件。没有退出条件的递归调用,就是无限调用
  2. 递归调用的深度不宜过深
    :Python对递归调用的深度做了限制,以保护解释器
    :超过递归深度限制,抛出RecursionError: maxinum recursion depth exceeded 超出最大深度
    :sys.getrecursionlimit()——CPython默认限制为1000,IPython默认是3000
#斐波那契数列Fibonacci number:1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144, ...
#循环写法
pre = 0
cur = 1
print(cur,end=' ')
n = 4
for i in range(n-1):
    pre,cur = cur,pre + cur
    print(cur,end=' ')
#如果设F(n)为该数列的第n项(n∈N*),那么这句话可以写成如下形式::F(n)=F(n-1)+F(n-2)
#递归写法
def fib(n):
    return 1 if n < 2 else fib(n-1) + fib(n-2)
三、递归性能
  1. 循环稍微复杂一些,但是只要不是死循环,可以多次迭代直至算出结果
  2. 递归还有深度限制,如果递归复杂,函数反复压栈,栈内存很快就溢出了
#上方斐波那契数列递归写法性能效率与循环写法相比极差
#结合循环写法改进斐波那契数列递归算法
def fib(n,pre=0,cur=1): 
    pre, cur = cur, pre + cur  
    if n == 0:
        return pre
    return fib(n-1,pre,cur)
四、间接递归
  1. 间接递归,是通过别的函数调用了函数自身。
  2. 如果构成了循环递归调用是非常危险的,但是往往这种情况在代码复杂的情况下,还是可能发生这种调用。要用代码的规范来避免这种递归调用的发生
#foo1 和 foo2 间接递归
def foo1():
    foo2()
def foo2():
    foo1()

foo1()
五、递归总结
  • 递归是一种很自然的表达,符合逻辑思维
  • 递归相对运行效率低,每一次调用函数都要开辟栈帧
  • 递归有深度限制,如果递归层次太深,函数反复压栈,栈内存很快就溢出了
  • 如果是有限次数的递归,可以使用递归调用,或者使用循环代替,循环代码稍微复杂一些,但是只要不是死循环,可以多次迭代直至算出结果
  • 绝大多数递归,都可以使用循环实现
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值