如题

  • 初步审题的时候,想到的是暴力搜索:初步设置一个合法的种子,依次按照1e-2,1e-3,1e-4,1e-5,1e-6 , 1e-7...暴力搜索,额,就是太麻烦了。

打比赛搜索写多了,一看见题目就想到搜索。。。

  • 细想了一下,进行优化,二分估值法,貌似很合适.
  • 试了试,又调了数学库求值开根号2 ,没问题。

代码

package com.szs;
/**
* @description 要求不用数学库,求 sqrt (2)精确到小数点后 10位
* @author Administrator
*/
public class Main {
public static void main(String[] args) {
//手写二分估值
System.out.println(myCalculate(1.4,1.4,1.5));
//调用函数输出
System.out.println("----------sqrt= "+Math.sqrt(2.0));
}
//根号2约等于 1.414
private static double myCalculate(double ans,double low,double high) {
double mid = 0;
// 二分法,结束条件:差值小于等于1e-10即可
while(high-low>1e-10){ mid = (high+low)/2.0;
System.out.println("-----------mid= "+mid+" mid*mid= "+mid*mid);
//二分,逐步向中间值收拢
if(mid*mid <= 2.0){
low=mid;
}
else{
high=mid;
} } return mid;
} }

测试输出结果

-----------mid= 1.45  mid*mid= 2.1025
-----------mid= 1.4249999999999998 mid*mid= 2.0306249999999997
-----------mid= 1.4124999999999999 mid*mid= 1.9951562499999995
-----------mid= 1.4187499999999997 mid*mid= 2.0128515624999994
-----------mid= 1.415625 mid*mid= 2.0039941406249997
-----------mid= 1.4140625 mid*mid= 1.99957275390625
-----------mid= 1.41484375 mid*mid= 2.0017828369140624
-----------mid= 1.414453125 mid*mid= 2.0006776428222657
-----------mid= 1.4142578125 mid*mid= 2.0001251602172854
-----------mid= 1.41416015625 mid*mid= 1.999848947525024
-----------mid= 1.414208984375 mid*mid= 1.9999870514869693
-----------mid= 1.4142333984375002 mid*mid= 2.000056105256081
-----------mid= 1.4142211914062501 mid*mid= 2.0000215782225137
-----------mid= 1.414215087890625 mid*mid= 2.000004314817488
-----------mid= 1.4142120361328125 mid*mid= 1.9999956831429155
-----------mid= 1.4142135620117187 mid*mid= 1.9999999989778732
-----------mid= 1.4142143249511718 mid*mid= 2.0000021568970987
-----------mid= 1.4142139434814451 mid*mid= 2.0000010779373403
-----------mid= 1.414213752746582 mid*mid= 2.00000053845757
-----------mid= 1.4142136573791504 mid*mid= 2.000000268717713
-----------mid= 1.4142136096954345 mid*mid= 2.0000001338477906
-----------mid= 1.4142135858535765 mid*mid= 2.0000000664128312
-----------mid= 1.4142135739326476 mid*mid= 2.000000032695352
-----------mid= 1.4142135679721832 mid*mid= 2.000000015836613
-----------mid= 1.414213564991951 mid*mid= 2.0000000074072433
-----------mid= 1.4142135635018347 mid*mid= 2.0000000031925578
-----------mid= 1.4142135627567767 mid*mid= 2.0000000010852155
-----------mid= 1.4142135623842478 mid*mid= 2.0000000000315445
-----------mid= 1.4142135621979832 mid*mid= 1.9999999995047089
-----------mid= 1.4142135622911156 mid*mid= 1.999999999768127
1.4142135622911156
----调用数学库计算-----sqrt2= 1.4142135623730951

【云栖社区002-二分估值法】要求不用数学库,求 sqrt (2)精确到小数点后10位(Java版)的更多相关文章

  1. [SoapUI] 重载JSONComparator比对JSON Response,忽略小数点后几位,将科学计数法转换为普通数字进行比对,在错误信息中打印当前循环的case number及其他附加信息

    重载JSONComparator比对JSON Response,忽略小数点后几位,将科学计数法转换为普通数字进行比对,在错误信息中打印当前循环的case number及其他附加信息 package d ...

  2. 云栖社区用机器人爬CSDN的文章?

    这个云栖社区的文章https://yq.aliyun.com/ziliao/539322 这篇文章是我13年写的,不知道咋插入图片,见谅. 下面是我的文件记录 分享XAML图标的网站 原创 2013年 ...

  3. 我的博客即将入驻“云栖社区”,诚邀技术同仁一同入驻。

    我的博客即将入驻"云栖社区",诚邀技术同仁一同入驻. 博客搬家邀请码NXLZV

  4. Vue.js 2 vs Vue.js 3的实现 – 云栖社区

    Vue.js 2 vs Vue.js 3的实现 – 云栖社区 vue.js核心团队已经讨论过将在Vue3实现的变化.虽然API不会改变,但是数据响应机制(译者注:对数据改变的监听和通知)发生了变化.这 ...

  5. 阿里巴巴高可用技术专家襄玲:压测环境的设计和搭建 PTS - 襄玲 云栖社区 今天

    阿里巴巴高可用技术专家襄玲:压测环境的设计和搭建 PTS - 襄玲 云栖社区 今天

  6. 云栖社区 Tensorflow快餐教程

    云栖社区 Tensorflow快餐教程(1) - 30行代码搞定手写识别:https://yq.aliyun.com/articles/582122云栖社区 Tensorflow快餐教程(2) - 标 ...

  7. 【云栖社区001-数据结构】如何实现一个高效的单向链表逆序输出(Java版)

    如题 动手之前,发现自己很擅长用C语言来写链表. 不过,既然自己做的是Java开发,那么还是用Java实现这个算法吧:毕竟,以后的若干年里都差不多要跟Java打交道了. 于是,先将Java版的链表自学 ...

  8. Docker:云栖社区开源论题及Spark开源论题

    https://yq.aliyun.com/topic/78?spm=5176.8290451.656547.7.rMYhAF https://yq.aliyun.com/activity/155?u ...

  9. 阿里云栖社区dubbo 资源整理

    1.apache dubbo pdf git 地址:https://github.com/dubbo/awesome-dubbo/tree/master/slides/meetup/201905%40 ...

随机推荐

  1. VUE 同一页面路由参数变化,视图不刷新的解决方案

    1.监听路由处理 watch: { $route(to, from) { // 逻辑 // 重新调用数据接口 } }, 2.beforeRouteUpdate导航守卫 路由更新时触发 beforeRo ...

  2. linux服务器之间文件传输

    有时候我们会遇到,把一个服务器上的文件夹,传到另一个服务器 我们需要先把文件夹打包成 tar.gz,这种格式在任何linux版本上都能压缩/解压 #解压命令 tar -zxvf xxx.tar.gz ...

  3. vs2017 vs2019 打开cs文件提示无法识别的GUID格式

    总结一句话 no zuo no die. 是我自己在注册表中给vs增加了自动以管理员身份运行,把值给错了,弄成了 ~ RUNASADMIN WIN7RTM, 改成 ~ RUNASADMIN 后OK.还 ...

  4. javascript中的this绑定问题

    this的绑定规则 1 默认绑定: function foo(){ console.log(this.a); } var a = 2 ; foo(); 调用 foo() 的时候其实相当于 window ...

  5. @PropertySource绝对路径(java.io.FileNotFoundException问题解决)

    经常使用@PropertySource 来指定配置文件,然后@value获取配置参数: @Component @PropertySource(value= {"classpath:rules ...

  6. 003 SpringBoot整合SpringMVC、Mybatis 案例

    1.不使用骨架创建一个maven工程 2.修改POM.xml文件 <?xml version="1.0" encoding="UTF-8"?> &l ...

  7. kafka 如何保证数据不丢失

    一般我们在用到这种消息中件的时候,肯定会考虑要怎样才能保证数据不丢失,在面试中也会问到相关的问题.但凡遇到这种问题,是指3个方面的数据不丢失,即:producer consumer 端数据不丢失  b ...

  8. 浅谈SQL Server事务与锁(上篇)

    一  概述 在数据库方面,对于非DBA的程序员来说,事务与锁是一大难点,针对该难点,本篇文章试图采用图文的方式来与大家一起探讨. “浅谈SQL Server 事务与锁”这个专题共分两篇,上篇主讲事务及 ...

  9. codeforces --- Round #250 (Div. 2) B. The Child and Set

    <传送门> [题目大意] 给你一个sum和一个limit,现在要你在1~limit中找到一些数来使得这些数的和等于sum,如果能找到的话就输出找到的数的个数和这些数,未找到输出" ...

  10. Delphi文字转语音TTS【支持选择语音库,播放,暂停,开始,停止,生成语音文件,设置音量,设置语速】

    作者QQ:(648437169) 点击下载➨文字转语音TTS [Delphi 文字转语音TTS]调用系统自带的TTS组件,支持XP,vista,win7,win8,win10系统,支持选择语音库,播放 ...