java 中平方根(sqrt)算法 的实例详解

2025-05-29 0 25

java 中平方根(sqrt)算法

平方根(sqrt, square root)是数学中常见的数学的公式;

使用程序进行求平方根主要分为两步:

第一步: while()循环, 控制循环次数及小数的位数, 防止无限循环和出现多位小数;

第二步: 通过分解平方根, 使用循环, 逐渐减小,接近平方根;

同理, 其他方根也可以类似扩展, 不过需要注意的是,
偶数次方根需要确保输入正数;
奇数次方根需要转换为正数, 确保循环收敛, 再进行结果正负判断;

代码如下:

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41
/*

* Algorithms.java

*

* Created on: 2013.12.03

* Author: Wendy

*/

/*eclipse std kepler, jdk 1.7*/

public class Algorithms

{

public static double sqrt(double c)

{

if(c<0) return Double.NaN; //NaN: not a number

double err = 1e-15; //极小值

double t = c;

while (Math.abs(t-c/t) > err*t) //t^2接近c, 防止小数

t = (c/t + t)/2.0;

return t;

}

public static double cbrt(double c)

{

boolean b = (c>0) ? true : false; //保存c的符号

c = (c>0) ? c : -c;

double err = 1e-15;

double t = c;

while(Math.abs(t*t-c/t) > err*t)

t = (c/(t*t)+t)/2.0;

t = (b) ? t : -t;

return t;

}

public static void main(String[] args)

{

double r = sqrt(4.0);

System.out.println("sqrt(4.0) = " + r);

double rc = cbrt(-27.0);

System.out.println("cbrt(9.0) = " + rc);

}

}

输出:

?

1

2
sqrt(4.0) = 2.0

cbrt(9.0) = -3.0

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

原文链接:http://blog.csdn.net/caroline_wendy/article/details/17114939

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 java 中平方根(sqrt)算法 的实例详解 https://www.kuaiidc.com/117983.html

相关文章

发表评论
暂无评论