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;
}
}
}