动态规划:青蛙跳台阶问题

本文探讨了青蛙跳台阶的经典问题,通过动态规划方法解决。利用状态转移方程Stage(n)=Stage(n-1)+Stage(n-2),解释了如何计算青蛙到达第10层台阶的所有可能选择。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题描述:青蛙可以一次跳一个台阶,也可以一次跳两个台阶,总共有10层台阶,青蛙有多少种选择

动态规划:设第n层的最多选择为Stage(n),根据题意,可得如下状态转移方程:
Stage(n)=Stage(n-1)+Stage(n-2)
如果n=10,则上述的意思就是第十层的选择等于第九层的选择数+第八层的选择数。(这是因为青蛙一次可以跳一个台阶,也可以一次跳两个台阶,当青蛙在第八层和第九层时都可以达到第十层)

def Stage(n):
    if n<0:
        return -1
    elif n==0:
        return 0
    elif n==1:
        return 1
    elif n==2:
        return 2
    else:
        dp=[]
        dp.append(0)
        dp.append(1)
        dp.append(2)
        for i in range(3,n+1):
            dp_tmp=dp[i-1]+dp[i-2]
            dp.append(dp_tmp)
    return dp[n]

print(Stage(10))

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值