f0622.cpp

来自「it is a usefull thing」· C++ 代码 · 共 45 行

CPP
45
字号
//==================================
// f0622.cpp
// 求素数个数,比较不同方法
//==================================
#include<iostream>
#include<bitset>
#include<time>
using namespace std;
//-----------------------------------
int sieveSTL();
int sieve();
//-----------------------------------
int main(){
  clock_t start = clock();
  cout<<sieve();
  cout<<" "<<(clock()-start)/CLK_TCK<<" sec\n";
  start = clock();
  cout<<sieveSTL();
  cout<<" "<<(clock()-start)/CLK_TCK<<" sec\n";
}//----------------------------------
int sieveSTL(){
  bitset<100000000>& p = *new bitset<100000000>;
  p.set();
  int num=100000000-2;           // except i=0,1
  for(int i=2; i<=10000; ++i)
    if(p.test(i))
      for(int j=i*i; j<p.size(); j+=i)
        if(p.test(j) && num--) p.reset(j);
  delete[] &p;
  return num;
}//----------------------------------
int sieve(){
  unsigned int* p = (unsigned int*)malloc(12500000);
  memset(p,-1,12500000);
  int num = 100000000-2;           // except i=0,1
  for(int i=2; i<=10000; ++i)
    if(p[i/32]&(1<<i%32))
      for(int j=i*i; j<100000000; j+=i)
        if(p[j/32]&(1<<j%32) && num--)
          p[j/32] &= ~(1<<j%32);
  free(p);
  return num;
}//==================================

 

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?