今天我做到一题:
(被5或6整除)找出能被5或6整除的前10个数字(大于Long.MAX_VALUE)
正确的答案是这样的
import java.math.BigInteger;
public class Exercise10_21 {
public static void main(String[] args) {
BigInteger m = BigInteger.valueOf(Long.MAX_VALUE);
int j = 0;
for(int i = 1; j<10 ; i++) {
BigInteger x = m.add(BigInteger.valueOf(i));
if((x.mod(BigInteger.valueOf(5)).equals(BigInteger.valueOf(0)) || x.mod(BigInteger.valueOf(6)).equals(BigInteger.valueOf(0)))) {
System.out.println(x);
j++;
}
}
}
}
9223372036854775810
9223372036854775812
9223372036854775815
9223372036854775818
9223372036854775820
9223372036854775824
9223372036854775825
9223372036854775830
9223372036854775835
9223372036854775836
但是一旦我先存入数组在输出答案
import java.math.BigInteger;
public class Exercise10_21 {
public static void main(String[] args) {
BigInteger m = BigInteger.valueOf(Long.MAX_VALUE);
BigInteger a[]= new BigInteger[10];
int j = 0;
for(int i = 1; j<10 ; i++) {
BigInteger x = m.add(BigInteger.valueOf(i));
if((x.mod(BigInteger.valueOf(5)).equals(BigInteger.valueOf(0)) || x.mod(BigInteger.valueOf(6)).equals(BigInteger.valueOf(0)))) {
a[j] = m.add(x);
System.out.println(a[j]);
j++;
}
}
}
}
18446744073709551617
18446744073709551619
18446744073709551622
18446744073709551625
18446744073709551627
18446744073709551631
18446744073709551632
18446744073709551637
18446744073709551642
18446744073709551643
输出的结果就翻倍了,请问这是为什么,以及解决办法。
你自己代码的问题 add两次
在 Java 中,有许多数字处理的类,比如 Integer类,但是Integer类有一定的局限性。
我们都知道 Integer 是 Int 的包装类,int 的最大值为 2^31-1。若希望描述更大的整数数据时,使用Integer 数据类型就无法实现了,所以Java中提供了BigInteger 类。
BigInteger类型的数字范围较Integer,Long类型的数字范围要大得多,它支持任意精度的整数,也就是说在运算中 BigInteger 类型可以准确地表示任何大小的整数值而不会丢失任何信息。
您好,我是有问必答小助手,你的问题已经有小伙伴为您解答了问题,您看下是否解决了您的问题,可以追评进行沟通哦~
如果有您比较满意的答案 / 帮您提供解决思路的答案,可以点击【采纳】按钮,给回答的小伙伴一些鼓励哦~~
ps:问答VIP仅需29元,即可享受5次/月 有问必答服务,了解详情>>>https://vip.csdn.net/askvip?utm_source=1146287632
非常感谢您使用有问必答服务,为了后续更快速的帮您解决问题,现诚邀您参与有问必答体验反馈。您的建议将会运用到我们的产品优化中,希望能得到您的支持与协助!
速戳参与调研>>>https://t.csdnimg.cn/Kf0y