跳台阶

作者: 克里斯加德纳 | 来源:发表于2017-11-20 15:13 被阅读0次

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

算法分析:
1.这题根据斐波那契数列公式
F(0) = 0;F(1)=1;F(2)=2; F(n)=F(n-1)+F(n-2)(n>=2,n∈N*) 跳到第N个位置的跳法只有从N-1跳到N和N-2跳到N两种情况,所以总的个数 F(n)=F(n-1)+F(n-2)

语言java
递归算法,在n较大时候递归的算法效率没有循环的高

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

循环算法 ,在n较大时候递归的算法效率没有循环的高

public class Solution {
    public int JumpFloor(int target) {
        if(target<0)
            return 0;
        if(target==1)
            return 1;
        if(target==2)
            return 2;
        int n1 = 1;
        int n2 = 2;
        int total = 0;
        for(int i = 3;i <= target; i ++ )
        {
            total = n1 + n2;
            n1 = n2;
            n2 = total;
        }
        return total;
    }
}

相关文章

  • 青蛙跳台阶--python

    一只青蛙可以一次跳 1 级台阶或者一次跳 2 级台阶,例如:跳上第 1 级台阶只有一种跳法:直接跳 1 级即可。跳...

  • 动态规划

    青蛙跳台阶问题 问题:一个青蛙,一次只能跳一级台阶,或者跳两级台阶,这个青蛙跳 n 级台阶有多少种跳法? 如果这只...

  • 跳台阶

    问题描述:?一次可以跳1级台阶,也可以跳2级台阶,问?跳上n级台阶有多少种跳法。 寻找递推关系:1.如果第一次跳1...

  • 算法---青蛙跳台阶问题

    一只青蛙可以一次跳一级台阶,也可以一次跳两级台阶,如果青蛙要跳上n级台阶,共有多少钟跳法? 问题分析 当青蛙即将跳...

  • 青蛙跳台阶问题

    青蛙跳台阶One 问题描述 一只青蛙一次可以跳1级台阶,也可以跳2级台阶。求该青蛙跳上一个级的台阶总共有多少种跳法...

  • 疯狂跳台阶

    ?一次可以选择跳1、2...n级台阶,问跳到n级台阶有多少种跳法 设F(n-i)表示第一次跳i(i

  • 面试题Fibonacci数列:一个台阶总共有n级,如果一次可以跳

    思路: 如果只有1 级台阶,只有一种跳法;如果有2 级台阶,那就有两种跳的方法了:一种是分两次跳,每次跳1 级;另...

  • 跳台阶问题

    跳台阶问题 题目描述: 一个台阶总共有 n 级,如果一次可以跳 1 级,也可以跳 2 级。求总共有多少种跳法,并分...

  • 榜样的力量

    昨晚跟小飞跳台阶。未等小飞开始,我就2级2级的往上跳。38级台阶,跳完后走下来继续。试着一次跳3级,不能连...

  • 跳台阶,生小兔(斐波那契数列)

    题目描述: 一个台阶总共有n级,如果一次可以跳1级,也可以跳2级。求总共有多少总跳法。分析:台阶数 1 2 3 4...

网友评论

      本文标题:跳台阶

      本文链接:https://www.haomeiwen.com/subject/qpyvvxtx.html