微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

java – 在检查BigInteger的可分性时,我应该使用mod还是余数?

当某个BigInteger b检查BigInteger a的可除性时,我可以编写a.mod(b).equals(BigInteger.ZERO)或a.remainder(b).equals(BigInteger.ZERO).

哪两个表达式更有效?

编辑:有几个人正确地指出mod不接受负模数.请假设答案中b为正数.

解决方法

这些方法间的区别记录在 Javadoc中.从 mod(m)开始:

This method differs from remainder in that it always returns a non-negative BigInteger.

此外,如果给定的参数为负数,则此方法抛出ArithmeticException,根据您的编辑,这不是您的情况.因此,为了测试可分性,mod和余数之间没有区别:当其中一个为0时,另一个也为0.你可以使用余数,因为mod可以进行另一个你不需要的计算.

要了解行动的不同,请考虑以下事项:

public static void main(String[] args) {
    BigInteger a = BigInteger.valueOf(-2);
    BigInteger b = BigInteger.valueOf(3);
    System.out.println(a.remainder(b)); // prints -2
    System.out.println(a.mod(b)); // prints 1 == -2 (i.e. the remainder) + 3
}

这实际上是原始int a和b与计算%b(其行为类似于余数)和Math.floorMod(a,b)(其行为类似于mod)的相同差异.

原文地址:https://www.jb51.cc/java/121584.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐