前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >剑指 Offer 10- II. 青蛙跳台阶问题

剑指 Offer 10- II. 青蛙跳台阶问题

作者头像
Vincent-yuan
发布2021-07-01 15:59:40
4720
发布2021-07-01 15:59:40
举报
文章被收录于专栏:Vincent-yuan

一只青蛙一次可以跳上1级台阶,也可以跳上2级台阶。

求该青蛙跳上一个 n 级的台阶总共有多少种跳法。

答案需要取模 1e9+7(1000000007),如计算初始结果为:1000000008,请返回 1。

示例 1:

输入:n = 2 输出:2

示例 2:

输入:n = 0 输出:1

提示:

  • 0 <= n <= 100

题解:

设跳上n级台阶有 f(n) 中跳法。

在所有跳法中,青蛙最后一步只有两种情况:跳上1级或者2级台阶。

  1. 当为1级台阶:剩余n-1个台阶,此情况共有 f(n-1) 种跳法;
  2. 当为2级台阶:剩余n-2个台阶,此情况共有 f(n-2)中跳法;

f(n) 为以上两种情况之和,即 f(n) = f(n-1) + f(n-2) .以上递推性质为斐波那契数列。

可转化为求斐波那契数列第n项的值。与10-1唯一不同在于,起始数字不同。

  • 青蛙跳台阶问题: f(0) = 1, f(1)=1, f(2) =2
  • 斐波那契数列问题: f(0)=0, f(1)=1, f(2)=1

依然可以用动态规范方式.

状态方程:dp[i+1] = dp[i] + dp[i-1] ,即对应数列定义 f(n+1) = f(n) + f(n-1) ;

初始状态:dp[0] = 1, dp[1] = 1, 即初始化前两个数。

返回值:dp[n]

代码语言:javascript
复制
    /**
     * 青蛙跳台阶问题
     * @param n
     * @return
     */
    public static int numWays(int n) {
        int a = 1,b=1,sum=0;
        for(int i=0;i<n;i++){
            sum = (a+b)%1000000007;
            a = b;
            b = sum;
        }
        return a;
    }
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021-06-28 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档