python关于斐波那契数列的实现,举例计算小兔子的数量,用迭代的方法没搞明白

python关于斐波那契数列的实现,举例计算小兔子繁衍的数量,第一个月数量为1,第二个月数量为1,第三个月开始,当月数量等于前两个月数量之和,计算第20个月的时候一共多少只兔子。用递归的方法能想明白,但是用迭代的方法有些地方看不懂,请各位指教。

img

# 递归方法实现
def fab(n):
    if n < 1:
        print("输入有误")
        return -1

    if n == 1 or n == 2:
        return 1
    else:
        return fab(n-1) + fab(n-2)

result = fab(20)
if result != -1:
    print(result)

img

迭代就是,已知前两个月的数量求第三个月的数量,为了节省空间,前两个月的数量可以用2个变量来表示,每次只要修改一下这两个变量。自己debug一下就懂了

艾玛,刚发完问题,回头再看了一遍,在纸上一步一步推演了一下,明白了~