一个高效率的素数算法(1千万以内的素数用我的破机器仅用1.3秒左右)

本文介绍了一种高效的素数搜索算法,并提供了完整的C++实现代码。该算法利用筛法原理,通过布尔数组标记非素数,有效提高了素数查找效率。文中还给出了搜索1到1000万范围内素数的具体示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#include "iostream.h"
#include "windows.h"
int searchprime(int num,int *out)
{
    int pn=0;
 long t1, t2;
    bool *mask=new bool[num+1];
 memset(mask, 0, sizeof(bool)*(num+1));
 t1 = GetTickCount();
    for(int i=2;i<=num;i++)
 {
        if(!mask[i])
        {
            out[pn++]=i;
            if(i<32767)
                for(int j=i*i;j<=num;j+=i)
                    mask[j]=true;
        }
 }
 t2 = GetTickCount();
 cout<<"用时:"<<t2 - t1<<"ms"<<endl;
    delete []mask;
    return pn;
}
void main()
{
    //int *out=new int[664579];
 int *out=new int[664579];
    cout<<"搜索1 ~ 10000000......"<<endl;
    int num=searchprime(10000000,out);
    cout<<"找到"<<num<<"个素数,最后一个素数是"<<out[num-1]<<endl;
 //for(int i=0;i<100;i++)
 //{
 // cout<<i<<":"<<out[i]<<endl;
 //}
    delete []out;
}

这个素数算法最初是在看雪上看到的,以前没想到过可以这样来求素数,非常经典,dwing的算法不错......

http://bbs.pediy.com/showthread.php?t=40052

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值