java中sqrt函数的详解[通俗易懂]

java中sqrt函数的详解[通俗易懂]一、原理:牛顿迭代法具体解释:牛顿迭代法求平方根那我们怎么用牛顿迭代法呢?首先要明白,牛顿迭代法求的是函数和X轴的交点的横坐标,也就是我们说的根1)那么第一步就是构建曲线了。假设有一个数c,我们求它的平方根x,那么有一个等式,x^2=c;挪到一边就是求f= x^2-c的根x2)带入上面的公式也就是 3)既然是个迭代,那么

大家好,又见面了,我是你们的朋友全栈君。

一、原理:牛顿迭代法

java中sqrt函数的详解[通俗易懂]

具体解释:牛顿迭代法求平方根

那我们怎么用牛顿迭代法呢?

首先要明白,牛顿迭代法求的是函数和X轴的交点的横坐标,也就是我们说的根

1)那么第一步就是构建曲线了。

假设有一个数c,我们求它的平方根x,那么有一个等式,x^2 = c;挪到一边就是求 f =  x^2 – c的根x

2)带入上面的公式

java中sqrt函数的详解[通俗易懂]

也就是 

java中sqrt函数的详解[通俗易懂]

3)既然是个迭代,那么就有迭代的开始和结束了

3.1)迭代的开始,我们可以取c

3.2)迭代的结束,就是和我们预期的很接近。

我们的预期是x^2 = c,那么变一下就是x = c / x 

 只要这两个数很接近,我们就停止迭代。。这就要设计一个精度了,我们设为 1e-7


二、java代码,sqrt函数

	public static double sqrt(double c){
		if(c < 0) return Double.NaN; //既然要开平方,肯定不能为负啊
		double err = 1e-7; //精度
		double x = c; //迭代的初始值
		while(Math.abs(x - c/x) > err){ //没达到精度,那么继续迭代
			x = (x + c/x) / 2.0;
		}
		return x;
	}




版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/139756.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • c语言offsetof_c语言宏定义比较大小

    c语言offsetof_c语言宏定义比较大小根据一个已经分配空间的结构体指针a中的某个成员b的地址,来获取该结构体指针地址

    2022年8月22日
    7
  • Ubuntu20.04下安装QQ[通俗易懂]

    https://blog.csdn.net/dulingwen/article/details/89848661https://blog.csdn.net/qq_36428171/article/details/81209475https://github.com/wszqkzqk/deepin-wine-ubuntuhttps://www.lulinux.com/archives/1319…

    2022年4月16日
    132
  • String转JSONArray,遍历JSONArray,Array数组转换成JSON字符串

    String转JSONArray,遍历JSONArray,Array数组转换成JSON字符串String转JSONArray, /** *String转JSONArray */ publicstaticvoidtest1(){ Stringjson="[{\"name\":\"张三\",\"code\":\"123\"},{\"name\":\"李四\",\"code\":\"123\"}]&quot

    2022年6月20日
    31
  • 计算机网络-划分子网 四大类必会题型

    计算机网络-划分子网 四大类必会题型必记知识点A类:0~126,默认子网掩码:255.0.0.0B类:128~191,默认子网掩码:255.255.0.0C类:192~223,默认子网掩码:255.255.255.0子网地址:网络号(照抄)+子网号(照抄)+主机号(全为0)广播地址:网络号(照抄)+子网号(照抄)+主机号(全为1)子网掩码:网络号(全为1)+子网号(全为1)+主机号(全为0)IP地址总数:根据主机号的位数得出可分配IP地址总数:主机数(IP地址总数-2)(减去全0和全1的

    2022年6月27日
    30
  • group by 和 order by 的区别 + 理解过程

    group by 和 order by 的区别 + 理解过程orderby和groupby的区别order by 和 group by 的区别:1,order by 从英文里理解就是行的排序方式,默认的为升序。 order by 后面必须列出排序的字段名,可以是多个字段名。2,group by 从英文里理解就是分组。必须有“聚合函数”来配合才能使用,使用时至少需要一个分组标志字段。注意:聚合函数是—sum()、count()、…

    2022年5月9日
    40
  • NFC手机模拟加密门禁卡[通俗易懂]

    NFC手机模拟加密门禁卡[通俗易懂]CSDN仅用于增加百度收录权重,排版未优化,日常不维护。请访问:www.hceng.cn查看、评论。本博文对应地址:https://hceng.cn/2019/07/12/NFC手机模拟加密门禁卡/#more记录小米手机NFC模拟加密门禁卡,以及Proxmark3的使用。0.缘起之前,小区用的门禁卡为非加密的门禁卡,使用小米手机系统自带的门卡模拟功能复制即可。后来,小区门禁系统换了…

    2022年5月1日
    933

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号