碎cup 2017-07-20 04:26 采纳率: 100%
浏览 1910
已采纳

用循环实现不死神兔(利用BigInteger完成),在i等于100就输出不了?还是说需要等待

public static void main(String[] args) {
System.out.println(function_2(100));
}
//求不死神兔
public static BigInteger function_2(int i){
if(i==1||i==2) {
BigInteger big=new BigInteger("1");
return big;
}
else{
BigInteger big1=function_2(i-2);
BigInteger big2=function_2(i-1);
BigInteger big=big1.add(big2);
return big;
}
}

  • 写回答

2条回答 默认 最新

  • SonOfWind0311 2017-07-24 01:35
    关注

    差不多每增加5运行次数增长11-12倍,到50就得一天了(实际上我设置成50,跑了一天多才出结果)。
    粗略算一下,i=50需要一天,每加5增长10倍,那么到100就是10的10次方,需要2000多万年才能执行完。

    10:
    calling times:109, time elapsed:0.005s

    11
    calling times:177, time elapsed:0.008s

    12:
    calling times:287, time elapsed:0.010s

    15:
    calling times:1219, time elapsed:0.025s

    20:
    calling times:13529, time elapsed:0.134s

    25:
    calling times:150049, time elapsed:0.781s

    30:
    calling times:1664079, time elapsed:6.698s

    35:
    calling times:18454929, time elapsed:64.653s

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启
  • ¥15 java写代码遇到问题,求帮助
  • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?
  • ¥15 加热介质是液体,换热器壳侧导热系数和总的导热系数怎么算
  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计