剑指offer----跳台阶问题

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

解法一:

public class Solution {
    public int JumpFloor(int target) {
        if(target <= 2){
            return target;
        }
        return JumpFloor(target - 1) + JumpFloor(target - 2);
    }
}

这种题目我们可以逆向的思考,青蛙从上一级跳到n级台阶有两种情况,即一次挑一步,和一次跳两步,也就是从n-1上跳过来,和从n-2上跳过来,然后再以此类推,跳到n-1也有两种方法.想清楚之后,这一定是一个递归的思路啊。写了代码之后发现这代码不就是斐波那契数列的递归形式吗!接上一篇的思路,仍可以用一个简单的迭代来实现。就不做具体介绍了
详见上一篇关于斐波那契问题的解答
https://www.jianshu.com/p/5ea3550f52a3

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • You are climbing a stair case. It takes n steps to reach ...
    stevewang阅读 5,356评论 0 3
  • 最近在准备一些暑期实习的笔试和面试,在牛客网上面做了一些题,现在整理出来供大家参考,希望和大家共同学习!题目不难,...
    Torang阅读 7,053评论 3 11
  • 最近在刷一些数据结构的题,发现个很有趣的问题:跳台阶问题。 1. 第一题(引子):输出菲波那切数列的第N项。 斐波...
    MentallyL阅读 7,913评论 1 6
  • 第一题: 在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数...
    我懒得取名阅读 3,153评论 0 0
  • 微信这个既能发送文字、又能发送图片声音,且能即时视频通话的社区交流媒体工具,确实大大的推进了人与人之间的交流,哪怕...
    城市屋檐下阅读 2,801评论 0 2

友情链接更多精彩内容