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