Pagini recente » Cod sursa (job #557114) | Cod sursa (job #10151) | Cod sursa (job #1333125) | Cod sursa (job #2870487) | Cod sursa (job #1364356)
#include <cstdio>
#include <vector>
#include <bitset>
#define Nmax 2000005
using namespace std;
bitset<Nmax> ciur;
vector<int> is_prime;
int N;
void sieve()
{
is_prime.push_back(2);
for(int i = 1; ((i<<1)|1) <= N; ++i)
if(ciur[((i<<1)|1)] == 0)
{
is_prime.push_back(((i<<1)|1));
for(int j = 1; ((i<<1)|1)*((j<<1)|1) <= N; ++j)
ciur[((i<<1)|1)*((j<<1)|1)] = 1;
}
printf("%d\n",is_prime.size());
}
int main()
{
freopen("ciur.in","r",stdin);
freopen("ciur.out","w",stdout);
scanf("%d",&N);
sieve();
return 0;
}