首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >变态跳台阶

变态跳台阶

作者头像
MickyInvQ
发布2021-12-30 21:42:05
发布2021-12-30 21:42:05
2660
举报
文章被收录于专栏:InvQ的专栏InvQ的专栏

题目描述

一只青蛙一次可以跳上 1 级台阶,也可以跳上 2 级… 它也可以跳上 n 级。求该青蛙跳上一个 n 级的台阶总共有多少种跳法。

解题思路

数学推导

跳上 n-1 级台阶,可以从 n-2 级跳 1 级上去,也可以从 n-3 级跳 2 级上去…,那么

代码语言:javascript
复制
f(n-1) = f(n-2) + f(n-3) + ... + f(0)

同样,跳上 n 级台阶,可以从 n-1 级跳 1 级上去,也可以从 n-2 级跳 2 级上去… ,那么

代码语言:javascript
复制
f(n) = f(n-1) + f(n-2) + ... + f(0)

综上可得

代码语言:javascript
复制
f(n) - f(n-1) = f(n-1)

代码语言:javascript
复制
f(n) = 2*f(n-1)

所以 f(n) 是一个等比数列

代码语言:javascript
复制
public int JumpFloorII(int target) {
    return (int) Math.pow(2, target - 1);
}
代码语言:javascript
复制
public int jumpFloorII(int target) {
    int[] dp = new int[target];
    Arrays.fill(dp, 1);
    for (int i = 1; i < target; i++)
        for (int j = 0; j < i; j++)
            dp[i] += dp[j];
    return dp[target - 1];
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021/12/30 ,如有侵权请联系 cloudcommunity@tencent.com 删除

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

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

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

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 题目描述
  • 解题思路
    • 数学推导
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档