首页 > 代码库 > 0-1亿里面素数的个数
0-1亿里面素数的个数
int sieve()
{
unsigned int* p=(unsigned int*)malloc(12500000); // 一个字节8个比特位
memset(p,-1,12500000);
int num=100000000-2;
for(int i=2;i<10000;i++)
{
if(p[i/32]&(1<<i%32)) // 判断第i位是否为1 如果为1 则表明i为素数
{
for(int j=i*i;j<100000000;j+=i)
{
// i的倍数为素数 ,将素数对应得比特位设为0 ,但需先判断该比特位是否为0
if(p[j/32]&(1<<j%32)&&num--) // 判断第j位是否为1 如果为1 ,num减少一
{
p[j/32] &=(~(1<<j%32)) // 将第j位设置为0
}
}
}
}
free(p);
return num;
}
0-1亿里面素数的个数
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。