Joylae 2013-08-20 09:37
浏览 282
已采纳

Java的一个循环效率问题

我写了一个简单,其中一个看似普通的循环却出乎了我的意料,是用Java写的。其中yz及pow的底数我现在改了一下:

//方法一:
double w = 0.0, yz = 1.234567;
for (int i = 0; i < currents.length; i++) {
    if (currents[i] > i2) {
        w += yz * currents[i] * Math.pow(1.56, i0/currents[i]);
    }
}
return w;


//方法二:
double w = 0.0, yz = 1.234567;
for (int i = pMax; i < currents.length; i++) {
    w += yz * currents[i] * Math.pow(0.89, i0/currents[i]);
}
return w;

 代码如上,现在问题就是照我的理解方法二应该比方法一快一些才对,而进行了测试方法一需要114ms,方法二需要333ms(进行了多次测试取平均)

我现在不知道到底是什么原因,所以上来请教讨论一下,谢谢各位!

- -|||  没分

  • 写回答

3条回答 默认 最新

  • _1_1_7_ 2013-08-20 10:08
    关注

    方法一中的循环体实际计算次数要比方法二少吧,所以就快;
    算法时间主要花在了计算Math.pow和两次乘法,循环本身的时间比计算时间少很多
    因为方法一有计算条件的约束所以计算时间就少花了很多

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

报告相同问题?

悬赏问题

  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 保护模式-系统加载-段寄存器