您的位置:首页 > 编程语言 > Java开发

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

2016-07-08 16:28 232 查看
问题描述:

人出生后,经过多少秒可以达到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岁


内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: