P50 递归函数 ----- 普通程序员用迭代,天才程序员用递归

1. 认识递归

递归就是函数调用自身的过程 给定参数让递归在恰当的时候回归 就实现了控制

def funA(i):
    if i > 0 :
        print('我爱Python')
        i -= 1
        funA(i)
funA(10)

2. 递归的优雅 ---- 递归和迭代的比较

① 计算阶乘

        采用for循环迭代:

def factIter(n):
    result = n
    for i in range(1,n):
        result *= i
    return result
print(factIter(5))

 

        采用递归函数:

def factIter1(n):
    if n == 1:
        return 1
    else:
        return n * factIter1(n-1)
print(factIter1(5))

② 计算斐波那契数列项数对应的值

         采用while循环迭代:

def fib(n):
    a = 1
    b = 1
    c = 1
    while n > 2:
        c = a + b
        a = b
        b = c
        n -= 1
    return c
print(fib(12))

         采用递归函数:

def fib1(n):
    if n == 1 or n == 2:
        return 1
    else:
        return fib1(n-1) + fib1(n-2)
print(fib1(12))

 

总结 :可以看到递归函数相较于迭代,显得更加优雅,更加接近于我们对一个问题的直白描述。

但是,递归的 ‘副作用’ 则是效率较低,每一次调用递归函数并不会立刻返回,要等最底层的那个函数返回,然后再一层一层地往上走,因此这个过程十分的消耗资源。例如将上面的递归函数fib1的实参改为120,则会发现代码卡很久都没有返回值。

注:本文内容总结于 《小甲鱼零基础入门学习python》视频课程P50

原视频链接:【Python教程】《零基础入门学习Python》最新版_哔哩哔哩_bilibili

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

汪小涵不记谱、

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值