返回顶部
首页 > 资讯 > 后端开发 > JAVA >Java中开根号,你还记得吗?
  • 476
分享到

Java中开根号,你还记得吗?

JavaMath类Java开根号数学运算sqrt 2023-09-12 09:09:51 476人浏览 八月长安
摘要

目录 前言一、了解根号运算二、Java开根号1.Math.sqrt()开平方根2.Math.pow()开根号3.牛顿迭代法来近似求解平方根 总结 前言 开根号相信大家都不陌生,这是一

目录


前言

开根号相信大家都不陌生,这是一种数学运算,也称为开方运算,运算符号是根号 √ ̄。那么在 Java 中如何实现开方运算呢?


一、了解根号运算

根号运算是一种数学运算,也称为开方运算。它的运算符号是 √ ̄,被称为根号符号,要将被开方的数包围。若 aⁿ=b,那么 abn 次方的 n 次方根或 ab1/n 次方。

n 次方的 n 写在符号 √ ̄ 的左边,n=2(平方根)时 n 可以忽略不写 x \sqrt{x} x ,但若是立方根(三次方根) x3 \sqrt[3]{x} 3x 、四次方根 x4 \sqrt[4]{x} 4x 等,是必须书写。

我们比较常见的也就是求一个数的平方根了,对于一个非负实数 x,它的平方根 y 是一个非负实数,使得 y 的平方等于 x,即 y²=x。例如, 4 \sqrt{4} 4 =2,因为 2²=4 9 \sqrt{9} 9 =3,因为 3²=9

需要注意的是,在实数范围内,负数没有实数平方根,因此,不能对负数进行开方运算,除非使用复数。

在计算中,可以利用计算器或数表等工具进行简便的根号运算,也可以通过手工计算,使用牛顿迭代法等算法进行近似计算。

二、Java开根号

1.Math.sqrt()开平方根

Java 中可以使用 Math 类的 sqrt 方法来实现平方根号运算。该方法的作用是返回一个数的平方根。
Math 类在 java.lang 包下,也是一个最终类,jdk1.0 就存在了。Math 类包含执行基本数值运算的方法,例如初等指数函数、对数函数、平方根函数和三角函数等。

public final class Math {}

Math 类中有 sqrt 方法,求平方根。以下是 sqrt() 方法源码

public static double sqrt(double a) {    return StrictMath.sqrt(a); // default impl. delegates to StrictMath   // Note that hardware sqrt instructions   // frequently can be directly used by JITs   // and should be much faster than doing   // Math.sqrt in software.}

我们可以看到该方法是静态方法,也就是可以通过 Math.sqrt() 直接调用。需要传入双精度 double 类型数值,返回的也是 double 类型数值。方法体很简单直接调用 StrictMath.sqrt(a); 它这里解释说默认的 impl,委托给 StrictMath

例如,要计算 9 的平方根,可以使用以下代码:

double result = Math.sqrt(9);System.out.println(result); // 输出结果为3.0

需要注意的是,sqrt 方法返回的是一个 double 类型的数值,如果需要精确计算,应该使用 BigDecimal 类进行计算。

我们在深究一下:

在 Java 中,根号运算被委托给了 Java 虚拟机中的 Math 库进行计算。Math 库中的 sqrt 方法采用了一些数学算法来求解开方运算,具体实现方式取决于底层的操作系统和硬件平台。

通常情况下,Java 虚拟机会使用硬件指令来进行数学计算,这样可以大大提高计算速度。对于无法使用硬件指令的情况,Java 虚拟机会使用软件实现的算法来进行计算。

无论使用哪种实现方式,Math 库的 sqrt 方法都会返回一个 double 类型的结果,表示被开方数的平方根。我们可以直接使用该结果进行后续的操作,例如计算平方根的倒数、平方等等。需要注意的是,sqrt 方法返回的结果并不是精确的,而是一个近似值,具体精度取决于底层实现的算法和硬件平台。如果需要进行高精度的计算,可以使用 BigDecimal 类来替代 Math 库中的方法。

2.Math.pow()开根号

在 Java 中,可以使用 Math 库的 pow 方法来进行求平方根的运算,但不是最有效的方法,因为 Math.pow() 通常使用指数函数来计算, 指数函数在近似计算时可能会导致精度误差。

如果要计算一个数的平方根,在 Java 中使用 Math.sqrt() 是更好的选择。sqrt() 方法是专门用来计算平方根的方法,它能保证对于任何非负数,都可以在不损失精度的情况下获得正确的平方根。

若要使用 Math.pow() 来求一个数 x 的平方根,可以使用以下代码:

Math.pow(x, 0.5)

这里,使用了 Math.pow(x, 0.5) 代表 x1/2 次幂,即其平方根。但是由于 Math.pow() 是用指数函数来计算的,可能会导致精度误差,因此不建议用这种方式来计算平方根。

3.牛顿迭代法来近似求解平方根

可以自己使用 Java 编写一个求平方根的方法。例如,可以使用 牛顿迭代法 来近似求解平方根。以下是网上一个简单的示例代码:简单测试没问题。

public static double mySqrt(double x) {    if (x < 0) {        throw new IllegalArgumentException("不能计算负数的平方根");    }    double guess = x / 2.0; // 初始值为x的一半    double tol = 1e-15; // 精度    int maxIter = 50; // 最大迭代次数    for (int i = 0; i < maxIter; i++) { // 进行迭代        double fx = guess * guess - x; // f(x)的函数值        double fpx = 2.0 * guess; // f'(x)的函数值(导数)        double diff = fx / fpx; // 迭代量        guess = guess - diff; // 更新猜测值        if (Math.abs(diff) < tol) { // 只要迭代量小于某个阈值就停止迭代            break;        }    }    return guess;}

在该代码中,mySqrt() 方法使用 牛顿迭代法 进行近似求解平方根。它接收一个 double 类型的参数 x,表示要计算平方根的数值。如果 x 是负数,则抛出 IllegalArgumentException 异常。接着,程序使用 x/2.0 作为初始猜测值,设置一些精度和迭代次数的参数,并进行迭代计算。每次迭代时,程序都会计算当前猜测值的平方,计算出 f(x)f’(x),然后更新猜测值。只要迭代量小于设定的精度,就停止迭代,并返回最终的猜测值作为平方根的近似值。


总结

本文主要讲解了 Java 中如何求一个数的平方根,先对根号运算进行了介绍,然后介绍了三种开根号方法,大家肯定要使用 Math.sqrt() 进行开平方根,第二、三种不建议使用。

来源地址:https://blog.csdn.net/Li_Ya_Fei/article/details/130388107

--结束END--

本文标题: Java中开根号,你还记得吗?

本文链接: https://www.lsjlt.com/news/404275.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作