Python 递归(recursion) 和 迭代(iteration)

    递归 (recursion) 是指在函数的定义中使用函数自身的方法,直观上来看,就是某个函数自己调用自己。递归的基本思想就是把规模大的问题转化为规模小的相同的子问题来解决。 在函数实现时,因为大问题和小问题是一样的问题,因此大问题的解决方法和小问题的解决方法也是同一个方法。这就产生了函数调用它自身的情况。递归的实现包含了两个部分,一个是递归主体,另一个是终止条件。因此递归函数需要设置好终止条件,避免出现无限递归的情况,导致程序崩溃。


    迭代:(iteration) 就是不断用旧的变量值,递推出新的变量值,每一次迭代得到的结果会作为下一次迭代的初始值。


    递归例子:


    (1) 阶乘 :



在这里插入图片描述



def fact(n):
    if n == 1:
      return 1
    return n * fact(n-1)

print(fact(4))


    (2) 斐波那契数列:前几个数列为: 0 1 1 2 3 5 8 13 21 34 55 89 144 233



在这里插入图片描述



def fibo(n):
    if n <= 1:
        return n
    else:
        return fibo(n-1) + fibo(n-2)

print(fibo(10))


    一些迭代例子:



在这里插入图片描述



list_of_numbers = [1, 2, 3, 4, 5, 6, 7, 8]
for num in list_of_numbers:
    print(num)


在这里插入图片描述



list_of_numbers = [1, 2, 3, 4, 5, 6, 7, 8]
for index, num in enumerate(list_of_numbers):
    print(f'Index {index}: {num}')


在这里插入图片描述



list_of_numbers = [1, 2, 3, 4, 5, 6, 7, 8]
squares = [num*2 for num in list_of_numbers]
print(squares)


在这里插入图片描述



my_dict = {'a': 1, 'b': 2, 'c': 3, 'd': 4, 'e': 5, 'f': 6, 'g': 7, 'h': 8}
for key, value in my_dict.items():
    print(f'Key: {key}, Value: {value}')
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值