para loop encontrando os números primos
Eu estou tentando executar esse código para imprimir a soma de todos os números primos menos de 2 milhões. Esse loop nunca termina. Alguém pode me dizer o que está errado com o código? Parece funcionar com números menores embora.
public static void main(String[] args) {
long result = 1;
for(int i=0; i<2000000; i++) {
if(isPrime(i)) {
result+= i;
}
}
System.out.println(result);
}
private static boolean isPrime(long n) {
boolean result = false;
for(long i=2; i<(long)Math.sqrt(n); i++) {
if(n%i == 0) {
result = false;
break;
}
else result = true;
}
return result;
}