java biginteger pow_java.math.BigInteger pow(指数)问题

我对pow(指数)方法做了一些测试.不幸的是,我的数学技能不足以解决以下问题.

我正在使用此代码:

BigInteger.valueOf(2).pow(var);

结果:

> var |时间以毫秒为单位

> 2000000 | 11450

> 2500000 | 12471

> 3000000 | 22379

> 3500000 | 32147

> 4000000 | 46270

> 4500000 | 31459

> 5000000 | 49922

看到? 2,500,000指数的计算速度几乎与2,000,000一样快. 4,500,000的计算速度比4,000,000快得多.

这是为什么?

为了给你一些帮助,这里是BigInteger.pow(exponent)的原始实现:

public BigInteger pow(int exponent) {

if (exponent < 0)

throw new ArithmeticException("Negative exponent");

if (signum==0)

return (exponent==0 ? ONE : this);

// Perform exponentiation using repeated squaring trick

int newSign = (signum<0 && (exponent&1)==1 ? -1 : 1);

int[] baseToPow2 = this.mag;

int[] result = {1};

while (exponent != 0) {

if ((exponent & 1)==1) {

result = multiplyToLen(result, result.length,

baseToPow2, baseToPow2.length, null);

result = trustedStripLeadingZeroInts(result);

}

if ((exponent >>>= 1) != 0) {

baseToPow2 = squareToLen(baseToPow2, baseToPow2.length, null);

baseToPow2 = trustedStripLeadingZeroInts(baseToPow2);

}

}

return new BigInteger(result, newSign);

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值