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

2023年 8月 21日 34.1k 0

前言

开根号相信大家都不陌生,这是一种数学运算,也称为开方运算,运算符号是根号 √ ̄。那么在 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() 方法源码:

/**
 * Returns the correctly rounded positive square root of a
 * {@code double} value.
 * Special cases:
 * 
  • If the argument is NaN or less than zero, then the result * is NaN. *
  • If the argument is positive infinity, then the result is positive * infinity. *
  • If the argument is positive zero or negative zero, then the * result is the same as the argument.
* Otherwise, the result is the {@code double} value closest to * the true mathematical square root of the argument value. * * @param a a value. * @return the positive square root of {@code a}. * If the argument is NaN or less than zero, the result is NaN. */ 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() 进行开平方根,第二、三种不建议使用。

相关文章

JavaScript2024新功能:Object.groupBy、正则表达式v标志
PHP trim 函数对多字节字符的使用和限制
新函数 json_validate() 、randomizer 类扩展…20 个PHP 8.3 新特性全面解析
使用HTMX为WordPress增效:如何在不使用复杂框架的情况下增强平台功能
为React 19做准备:WordPress 6.6用户指南
如何删除WordPress中的所有评论

发布评论