在Java中使用BigDecimal手动Math.pow

时间:2017-03-07 13:07:38

标签: java bigdecimal exponent

我正在尝试编写Math.pow的手动代码,并且也使用BigDecimal数据类型,因为我稍后会处理非常小的值。

我得到了math.pow的这段代码,然后我尝试将其转换为BigDecimal。

public static double power(double base, int exponent) {
double ans = 1;
if (exponent != 0) {
    int absExponent = exponent > 0 ? exponent : (-1) * exponent;
    for (int i = 1; i <= absExponent; i++) {
        ans *= base;
    }

    if (exponent < 0) {
        // For negative exponent, must invert
        ans = 1.0 / ans;
    }
} else {
    // exponent is 0
    ans = 1;
}

return ans;
}
}

我将double和int数据类型转换为BigDecimal并尝试相应地更改代码,但不知怎的,我没有得到正确的结果。

 public static BigDecimal powerBig(BigDecimal base, BigDecimal exponent) {

    BigDecimal ans=  new BigDecimal(1.0);
    BigDecimal k=  new BigDecimal(1.0);
    BigDecimal t=  new BigDecimal(-1.0);
    BigDecimal no=  new BigDecimal(0.0);

    if (exponent != no) {
         BigDecimal absExponent =  exponent.signum() > 0 ? exponent : t.multiply(exponent);
        for (int i =  1 ; i <= absExponent.signum(); i++) {
            ans =ans.multiply(base);
        }

        if (exponent.signum() < 0) {
            // For negative exponent, must invert
            ans = k.divide(ans);
        }
    } else {
        // exponent is 0
        ans = k;
    }

    return ans;
}

我正在尝试在

上运行它
 BigDecimal check =  new BigDecimal (4.0);
 BigDecimal Euler = new BigDecimal (2.7182818);

  powerBig(Euler,check);

但我得到的所有输出都是欧拉值。有人可以帮我解决我的代码中的错误吗?

在将指数类型更改为int

之后,代码现在运行
public static BigDecimal powerBig(BigDecimal base, int exponent) {

    BigDecimal ans=  new BigDecimal(1.0);
    BigDecimal k=  new BigDecimal(1.0);
    //BigDecimal t=  new BigDecimal(-1.0);
    //BigDecimal no=  new BigDecimal(0.0);

    if (exponent != 0) {
         int absExponent =  exponent > 0 ? exponent :  (-1)*exponent;
        for (int i =  1 ; i <= absExponent; i++) {
            ans =ans.multiply(base);
        }

        if (exponent < 0) {
            // For negative exponent, must invert
            ans = k.divide(ans);
        }
    } else {
        // exponent is 0
        ans = k;
    }

    return ans;
}

1 个答案:

答案 0 :(得分:1)

你的问题是BigDecimal.sigNum()返回1,0或-1,如果数字是正数,零或负数,那么absExponent.sigNum()将总是返回1,你的循环将在它第一次执行时结束< / p>

此版本适用于euler示例

public static BigDecimal powerBig(BigDecimal base, BigDecimal exponent) {

    BigDecimal ans=  new BigDecimal(1.0);
    BigDecimal k=  new BigDecimal(1.0);
    BigDecimal t=  new BigDecimal(-1.0);
    BigDecimal no=  new BigDecimal(0.0);

    if (exponent != no) {
        BigDecimal absExponent =  exponent.signum() > 0 ? exponent : t.multiply(exponent);
        while (absExponent.signum() > 0){
            ans =ans.multiply(base);
            absExponent = absExponent.subtract(BigDecimal.ONE);
        }

        if (exponent.signum() < 0) {
            // For negative exponent, must invert
            ans = k.divide(ans);
        }
    } else {
        // exponent is 0
        ans = k;
    }

    return ans;
}

BigDecimal类也有pow功能,所以如果你想保持简单,你可以放

 BigDecimal Euler = new BigDecimal (2.7182818);
 Euler.pow(4);