单变量求解的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,也慢慢的展现出来其羞涩的一面。
代码如下:
运行结果:
经过2207520001秒,达到70岁
人出生后,经过多少秒可以达到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岁
相关文章推荐
- There is an error in invoking javac. A full JDK (not just JRE) is required问题解决
- Struts2数据传输的背后机制:ValueStack(值栈)
- SpringMVC+MyBatis声明式事务管理
- 在IntelliJ IDEA上将WSDL生成Java代码
- JAVA POI关闭Workbook
- spring+shiro 整合之自己注册会话和自写realm
- java查看当前项目所有线程列表界面【转】
- Spring源码分析心得-Bean的读取和注册
- Java设计模式之责任链模式(Chain of Responsibility模式)介绍
- 浅谈Java设计模式(二)抽象工厂模式
- Java四种线程池的使用
- Spring Boot 快速入门
- Myeclipse2014破解步骤
- Initialize List<List<Integer>> in Java 怎么初始化List<List<Integer>>
- Spring为web开发提供的一个类 org.springframework.web.filter.CharacterEncodingFilter
- Java NIO使用及原理分析(一)
- 《java设计模式》之责任链模式
- Java---三种文件拷贝的实现方法
- myeclipse+maven实现多模块项目struts+spring+mybatis
- 关于Spring的69个面试问答——终极列表