1
public class Problem3 {

    public static void main (String args[]) {
        System.out.print(primeMod(60085147514L));
    }

    public static double primeMod(long d) {
        long max = 0;
        int count = 0;

        for (long i = 2; i < d; i++) {
            if (d % i == 0) { 
                boolean isPrime = primeCounter(i);
                if(isPrime == true) { 
                    max = i;
                    System.out.println(max);
                }
            } else {
                max = max;
            }
        }

        return max;
    }

    public static boolean primeCounter(long x) {
        int count = 0;
        for (int s = 1; s <= x; s++) {
            if (x % s == 0) {
                count++;
            }
        }

        if (count == 2) {
            return true;
        } else {
            return false;
        }
    }
}

私のプログラムは小さい数で動作しますが、ゼロ除算ではない場合、ゼロ除算のアーティメティック例外がスローされます。答えを教えないでください。理解してスキルを向上させたいだけです。ありがとうございます。

4

1 に答える 1

4

私の推測では、それsはあふれ、最終的にはゼロ除算につながります。代わりに作成sしてください。long

于 2012-09-26T22:23:41.960 に答える