剑指offer算法题笔记总结之跳台阶和斐波那契

1.斐波那契数列入门方法就是递归方式,即f(n)=f(n-1)+f(n-2);其中n=1,2时都等于1,但是递归方法在很多时候都是性能比较差的一种算法,因为在计算的时候会涉及很多重复的计算,比如算F5,就需要计算F4.F3,计算F4就又需要计算F3,从F5开始分成的两支会有很多值被重复计算,浪费了效率,我看大家都说面试的时候不推荐写,我写了一下确实,测试用例500ms,用了自底向上循环迭代的方法,只有十几ms,可以使用这种方式,
这里给的是青蛙上台阶的样例,和斐波那契基本一致,只不过多了f0=1的定义,也就是f1=1,f2=2;

public class Solution {
    public int JumpFloor(int target) {
        if(target <= 1){
            return 1;            
        }else {
        //这里的a和b表示的是计算的起始条件,也就是n=1和2的情况,其中a代表f(n-1),b代表f(n-2).
        
            int a = 2;
            int b = 1;
            for(int i =3;i <= target; i++){
            a = a + b;     //进入for循环迭代以后,a代表f(n),
            b = a - b;     //b代表从原来的f(n-2)变成f(n-1),一直替换计算,这样就不会出现递归地重复计算
            
        }
        return a;
        }
    }
}

你可能感兴趣的:(Daily,算法,java,leetcode)