为什么这会给我一个java中的算术错误?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了为什么这会给我一个java中的算术错误?相关的知识,希望对你有一定的参考价值。
所以出于某种原因,这给了我0分误差,任何想法?
package euler;
public class LargePrimeFactor {
public static long max = 600851475143L;
public static int isPrime() {
int count = 0;
for(int i = 1; i < max; i++) {
if(max % i == 0)count += i;
}
return count;
}
public static void main(String[] args) {
System.out.println(max/isPrime());
}
}
答案
变量i
是int
类型。 The maximum value of an int
is (2^31) - 1 = 2147483647
。当你将一个加到最大的int
值时,它会溢出,成为最小的int值(-2^31 = -2147483648
)。这被称为ring arithmetic继续向此变量添加1,它最终将成为0
,导致DivisionByZeroException
(记住,division and modulus are semantically coupled)。
顺便说一下:通过相同的推理,你可以看到i < max
永远是真的。
另一答案
你得到这个错误,因为i
导致overflow
之后Integer.MAX_VALUE
的值将是Integer overflow
。你的max
是一种long
持有值600851475143L
(大于Integer.MAX_VALUE),但i
是int。所以在某个时间点,由于i
,0
最终将到达overflow
并且max % i
= 600851475143L/0
将抛出错误。为了解决这个问题,我建议制作i
类型的长。
long count = 0;
for(long i = 1; i < max; i++) {
if(max % i == 0)count += i;
}
以上是关于为什么这会给我一个java中的算术错误?的主要内容,如果未能解决你的问题,请参考以下文章
为啥 TypeScript 中的 'instanceof' 会给我错误“'Foo' 仅指一种类型,但在这里被用作值。”?