[剑指offer][08]跳台阶

题目描述:

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

解题思路:

由题意,可得:
青蛙跳上第n层台阶的跳法=青蛙跳上第n-1层台阶的跳法+青蛙跳上第n-2层台阶的跳法
即:
f(n)=f(n-1)+f(n-2)
是不是有点眼熟,本质就是 「斐波那契数列」(解法见[剑指offer][07]斐波那契数列

代码实现:
class Solution {
public:
    int jumpFloor(int number) {
        //本质为斐波那契数列
        if(number==0||number==1){
            return 1;
        }
        int step1,step2,res;
        step1=1;
        step2=1;
        res=1;
        for(int i=2;i<=number;i++){
            res=step1+step2;
            step1=step2;
            step2=res;
        }
        return res;
    }
};
引用链接

跳台阶问题 + 变态跳台阶问题 解法(动态规划递归 + 非递归)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 前言 2. 实现 Singleton 3. 数组中重复的数字 4. 二维数组中的查找 5. 替换空格 6. 从尾到...
    Observer_____阅读 2,970评论 0 1
  • 最近在准备一些暑期实习的笔试和面试,在牛客网上面做了一些题,现在整理出来供大家参考,希望和大家共同学习!题目不难,...
    Torang阅读 2,412评论 3 11
  • 二维数据中的查找 题目描述 在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排...
    EarthChen阅读 1,211评论 0 1
  • 题目六:旋转数组的最小数字 题目描述:把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。输入一个非...
    管弦_阅读 138评论 0 0
  • 变态跳台阶 题目描述 一只青蛙一次可以跳上1级台阶,也可以跳上2级……它也可以跳上n级。求该青蛙跳上一个n级的台阶...
    McRay阅读 510评论 0 0