剑指 - 跳台阶

跳台阶

http://www.nowcoder.com/questionTerminal/8c82a5b80378478f9484d87d1c5f12a4

迭代

本质上还是斐波那契数列,所以迭代也可以求

当成 dp 问题来想的话:首先分析问题,它最终解是由前面的解累积起来的解,如何缩小问题的规模?

首先可知,第一阶有只能一步,一种;,第二阶可以两次一步、一次两步两种

  • 若楼梯阶级 n = 3
    • 跳 2 步到 3:剩下的是第一步没跳,起始跳到第一步只有一种
    • 跳 1 步到 3:剩下的是第二步没跳,起始跳到第二步有两种

通过分类讨论,问题规模就减少了:

  • 若楼梯阶级 n = n
    • 跳 2 步到 n:剩下的是第 n - 2 步没跳,起始跳到第 n - 2 步设它为 pre2 种
    • 跳 1 步到 n:剩下的是第 n - 1 步没跳,起始跳到第 n - 1 步设它为 pre1 种

同时可以发现第 n 阶的解法,只要用到 n - 1 和 n - 2 阶是多少,其他的不用考虑,因此用两个变量临时存下来即可

dp(i) = dp(i-2) + dp(i-1)

public class Solution {
    public int JumpFloor(int target) {
        if(target <= 2){
            return target;
        }
        int pre2 = 1, pre1 = 2;
        for (int i = 3; i <= target; i++){
            int cur = pre2 + pre1;
            pre2 = pre1;
            pre1 = cur;
        }
        return pre1;
    }
}
全部评论
麻烦问一下?为何在台阶数为 1 的时候不能有 2 种呢(题目没有规定要求台阶数之和要一定是跳的台阶数之和吧),在台阶数如果是 2 时,难道不是有三种吗?( 1,1; 1,2; 2 )难道在第一次跳 1 个台阶,还剩下 1 个台阶,它再跳 2 不行吗????其他台阶数类推。
1 回复 分享
发布于 2019-11-22 02:26
谢谢
1 回复 分享
发布于 2019-10-26 11:41
清楚透彻!
1 回复 分享
发布于 2019-08-12 21:48
这思路一点也不斐波那契
点赞 回复 分享
发布于 2020-05-22 19:23
清楚,这也解释了为什么本道题可以用斐波那契数列来解决。
点赞 回复 分享
发布于 2020-03-16 11:43

相关推荐

2025-12-31 18:42
复旦大学 Java
点赞 评论 收藏
分享
2025-11-13 14:37
门头沟学院 Java
程序员牛肉:是的,我觉得你最先需要的是多接触计算机圈子。我感觉你这个写的太幼稚了,根本没换位思考面试官。 你对实习的描述还是我写了前后端,我写了Restful接口,我用了EChatrs。你这让面试官怎么问你?问你什么是前后端?问你什么是Restful?讲真的兄弟,你这个简历在面试官眼里就是啥也不懂的好学生。所以一定要尽快加入一个圈子跟大家多聊聊,看看正儿八经的简历是怎么写的。 可以看一下我首页的简历怎么写那篇文章来学一下,你这里面的坑点我那篇文章里面都有讲过。
点赞 评论 收藏
分享
评论
68
3
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务