判断素数方法

个人常用判断素数方式:

bool prime(int n)
{
    if(n<2) return false;
    for(int i=2;i<n;i++)
        if(n%i==0)  return false;
    return true;
}


相对而言,速度较快些的写法:

bool prime(int n)
{
    if(n<2) return false;
    for(int i=2;i<=sqrt(n);i++)
        if(n%i==0)  return false;
    return true;
}


筛选法求素数

所谓“筛选法”指的是“埃拉托色尼(Eratosthenes)筛法”。他是古希腊的著名数学家。他采取的方法是,在一张纸上写上1到100全部整数,然后逐个判断它们是否是素数,找出一个非素数,就把它挖掉,最后剩下的就是素数。

具体做法:

<1> 挖去1;
<2> 用刚才被挖去的数的下一个数p去除p后面各数,把p的倍数挖掉;
<3> 检查p是否小于n^2的整数部分(如果n=1000, 则检查p<31?),如果是,则返回(2)继续执行,否则就结束;
<4> 纸上剩下的数就是素数。

***********************


高效地判断素数法

素数出现规律:

当n≧5时,如果n为素数,那么n mod 6 = 1 或 n mod 6 = 5,即n一定出现在6x(x≥1)两侧。


bool isPrime(int num)
{
    if (num==2 || num==3)         return true;
    if (num%6!= 1 && num%6!=5)         return false;
    for (int i=5; i*i<=num; i+=6){
        if (num%i==0 || num%(i+2)==0)
            return false;
    }
    return true;
}





你可能感兴趣的:(素数)