单变量求解的Java实现及其与Excel的Goal Seek性能比较(Java完胜)

来源:互联网 发布:设计家具的软件 编辑:程序博客网 时间:2024/06/18 04:46

问题描述:

人出生后,经过多少秒可以达到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,也慢慢的展现出来其羞涩的一面。


代码如下:

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岁


0 0
原创粉丝点击