单变量求解的Java实现及其与Excel的Goal Seek性能比较(Java完胜)
问题描述:
人出生后,经过多少秒可以达到70岁?
1. 小学生的解法(可能是最聪明的解法,没有Java/Excel什么事了):70年对应的秒数=70*365天*24小时*60分*60秒=70*365*24*60*60=2207520000秒
2. Java的实现:最笨的办法,使用循环暴力查找匹配值(详见代码部分,由于循环次数已超过了int型的上限:2147483647,故采用long型作为循环控制变量)(10秒内出结果:2207520001秒)
3. Excel中,设单元格1为0,单元格2为:单元格1/(365*24*60*60),然后用Data->Data Tools->What-if Analysis->Goal Seek工具进行求解运算,半天也出不来结果。一直以来让我感到强大无比的Excel,也慢慢的展现出来其羞涩的一面。
代码如下:(2018年12月30日优化)
public class Age
{public static void main(String[] args){long secondsPassed=0;final int targetYear=70;int yearsPassed =0;do{yearsPassed = (int)(++secondsPassed/3600/24/365);}while (yearsPassed-targetYear<0);System.out.printf("经过%d秒,达到70岁\n",secondsPassed);}
}
运行结果:
经过2207520000秒,达到70岁
(2016-07-08版本——有点笨拙)
public class Age
{public static void main(String[] args){long secondsPassed=0;long targetYear=70;long targetSecondsPassed=0;for(long i=1;i<=10000000000L;i++){year=secondsPassed/3600/24/365;secondsPassed+=1;if(year-targetYear>=0){targetSecondsPassed=secondsPassed;break;} }System.out.printf("经过%d秒,达到70岁\n",targetSecondsPassed);}
}
运行结果:
经过2207520001秒,达到70岁
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:https://dhexx.cn/news/show-12253.html
如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网进行投诉反馈,一经查实,立即删除!