嗨,我有一个算法,其中我需要将操作应用于BigInt。
我知道可以使用数学类来操作BigInt,例如:
import java.math.*;
BigInteger a;
BigInteger b = BigInteger.ZERO;
BigInteger c = BigInteger.ONE;
BigInteger d = new BigInteger ("3");
BigInteger e = BigInteger.valueOf(5);
a.multiply(b);
a.add(b);
a.substract(b);
a.divide(b);我需要能够申请超过一段时间的条件。
while (a > 0) {这给了我一个语法错误,说“二元运算符'>‘的操作数类型不好,第一种类型: java.math.BigInteger,第二种类型: int。
我还需要能够将模(%)运算符应用于BigInteger。
b = a % c;有没有人能建议一种这样做的方法?
如果没有解决方案,那么我将不得不以某种方式使用reduce函数将我的BigInteger操作为一个唯一的长整型(这并不理想)。
Silverzx。
发布于 2013-03-02 00:01:58
要比较BigInteger,请使用BigInteger.compareTo。
while(a.compareTo(BigInteger.ZERO) > 0)
//...对于模(%),使用BigInteger.mod。
BigInteger blah = a.mod(b);发布于 2013-03-02 00:00:19
为了比较BigIntegers,您可以使用compareTo,但在特殊情况下,当您将其与0进行比较时,signum方法也可以完成这项工作(而且可能会更快一些)。至于取给定除法的余数,您可以使用mod方法(这里是更好的选项),或者使用divideAndRemainder,它返回一个同时包含除法和余数结果的数组。
https://stackoverflow.com/questions/15161639
复制相似问题