1

我知道这不是找到素数的最好方法,也不是最有效的方法。但是,我似乎找不到 169 算作质数的原因(就我而言,对于较小的数字,它可以正常工作)。

public static int checkPrime(int num, int i)
{
    if (i == num)
        return 1;

    else
    {
        if (num % i == 0)
            return 0;
        else
            checkPrime(num, i+1);

    }

    return 1;
}

主类:

        System.out.println("Type a number");
        number = reader.nextInt();

        if ((number % 10) % 2 == 0)
            result = 0;

        else
            result = checkPrime(number, 2);

        if (result == 1 || number == 2)
            System.out.println(number + " is a prime number");
        else
            System.out.println(number + " is NOT a prime number");
4

1 回答 1

6

替换intbyboolean以获得更好的表现力,并返回递归调用的值,您的方法如下所示:

public static boolean checkPrime(int num, int i)
{
    if (i == num)
        return true;    
    else
    {
        if (num % i == 0)
            return false;
        else
            return checkPrime(num, i+1);
    }
}

它仍然不起作用num < 2,它将运行直到i溢出。因此,作为您的主要素数检查功能,您可以编写如下内容:

public static boolean checkPrime(int num)
{
   if(num<2)
     return false;
   else
     return checkPrime(num, 2);
}

顺便说一句(number % 10) % 2,相当于number % 2.

于 2012-05-12T10:44:55.650 回答