判断素数方法

个人常用判断素数方式:

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;
}





评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

黎轩栀海

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值