斐波那契数列“不死神兔”的几种算法比较

 

 

题设:

若有一只免子每个月生一只小免子,一个月后小免子也开始生产。起初只有一只免子,一个月后就有两只免子,二个月后有三只免子,三个月后有五只免子(小免子投入生产)......。

这就是著名的不死神兔问题,即Fibonacci数列,一般习惯称之为费氏数列,举例如下: 1、1 、2、3、5、8、13、21、34、55、89......

分析结果显然可以看到,每相邻两个数之和等于第三个数;

下面分别用几种算法实现,比较时间开销;

第三种:使用动态数组模式,效率最高,重复计算最少

public class RabbitDemo {
    public static void main(String[] args) {
        long l = System.currentTimeMillis();
        for (int i =1;i<30;i++){
          sumRabit3(i);
        }
        long l2 = System.currentTimeMillis();
        System.out.println("总耗时"+(l2-l));
    }
    private static void sumRabit3(int i) {
        int [] arr = new int[i];
        for (int j = 0; j < arr.length; j++) {
            if (j == 1||0==j) {
                arr[j]=1;
            }else {
                arr[j]=arr[j-1]+arr[j-2];
            }

        }
        String s = Arrays.toString(arr);
        System.out.println(s);
       // return arr[i-1];
    }
}

方式二:使用递归

    
public class RabbitDemo {
    public static void main(String[] args) {
        long l = System.currentTimeMillis();
        for (int i =1;i<30;i++){
          sumRabit(i);
        }
        long l2 = System.currentTimeMillis();
        System.out.println("总耗时"+(l2-l));
    }
    private static int sumRabit(int month) {
        if (month==1||month==0)
        {
           return 1;
        }else {
            int sum = sumRabit(month - 1) + sumRabit(month - 2);
            return sum;
        }
    }

方法一:思路,将前面每个月计算过的值,存入map,后面每次计算的时候从map取值,并将计算后的值添加进map,实际测试计算耗时并无优势,代码需优化,暂不贴代码了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值