剑指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;
        }
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值