首页 > 其他 > 详细

跳台阶

时间:2020-03-07 15:44:55      阅读:99      评论:0      收藏:0      [点我收藏+]

题目描述
一只青蛙一次可以跳上1级台阶,也可以跳上2级。求该青蛙跳上一个n级的台阶总共有多少种跳法(先后次序不同算不同的结果)。

C++11(clang++ 3.9)

class Solution {
public:
    int jumpFloor(int number) {
        // f(0) = 0
        // f(1) = 1
        // f(2) = 2
        // ...
        // f(n-2) = f(n-3) + f(n-4)
        // f(n-1) = f(n-2) + f(n-3)
        // f(n)   = f(n-1) + f(n-2)
        
        if(number <= 0) return 0;
        if(number == 1) return 1;
        if(number == 2) return 2;
        
        int small = 1;
        int large = 2;
        int ret = 0;
        
        for(int i = 0; i < number - 2; i++)
        {
            ret = large + small;
            small = large;
            large = ret;
        }
        return ret;
    }
};

 

跳台阶

原文:https://www.cnblogs.com/hotwater99/p/12434495.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!