走楼梯问题

本文探讨了一个经典的数学问题——下楼问题,即如何计算从楼上走到楼下所有可能的路径数量。该问题可通过递归和迭代两种方法解决,并与斐波那契数列紧密相关。
'''
下楼问题。从楼上走到楼下共有h个台阶,每一步有两种走法:
走1个台阶,走2个台阶,问有多少可走的方案。用递归思想和迭代思想编程
'''

'''
分析:问题可以从最后一次是走1步还是两步,反向考虑
'''

def take_stairs_recursive(n):
    if n == 1:
        return 1
    elif n == 2:
        return 2
    else:
        return take_stairs_recursive(n-1)+take_stairs_recursive(n-2)

'''
其实就是斐波那契数列
'''
def take_stairs(n):
    if n == 1:
        return 1
    if n == 2:
        return 2
    a,b = 1,2
    result = 0
    for i in range(3,n+1):
        result = a + b
        a = b
        b = result
    return result

print(take_stairs_recursive(10))
print(take_stairs(10))

 

转载于:https://www.cnblogs.com/hupeng1234/p/6680631.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值