一个高效率的素数算法(1千万以内的素数用我的破机器仅用1.3秒左右)
来源:互联网 发布:网络桥接是什么意思 编辑:程序博客网 时间:2024/06/05 10:56
#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千万以内的素数用我的破机器仅用1.3秒左右)
- 100以内的素数(用flag)
- 千以内的素数
- 一千以内的素数
- 一百万以内的素数
- 1000以内的素数
- 1000以内的素数
- 10000以内的素数
- 10000以内的素数
- 100以内的素数
- 求一亿以内的素数
- 一百以内的素数
- 100以内的素数
- 100以内的素数
- 100以内的素数
- 输出1000以内的素数的算法
- js: 输出一个数以内的素数
- 求100以内的素数算法
- 报表演变历史-分组报表-小计合计
- Oracle用户权限管理【转】
- 一个程序员的奋斗历
- 为开发人员提供的需求管理实践
- 我所知道的计算机顶级会议排名
- 一个高效率的素数算法(1千万以内的素数用我的破机器仅用1.3秒左右)
- 企业管理可向寺院学习
- 在Tomcat中配置运行jbpm-3.0自带的websale
- 如何更好的控制客户需求
- 职业经理人应该如何制定决策
- 报表演变历史-分组报表-老外习惯
- FolderBrowserDialog实现默认选中上次选择的目录
- RequisitePro中需求管理的12个步骤
- project euler problem 11