Pagini recente » Cod sursa (job #2576288) | Cod sursa (job #2416062) | Cod sursa (job #645560) | Cod sursa (job #2726385) | Cod sursa (job #868298)
Cod sursa(job #868298)
#include <iostream>
#include <cstdio>
using namespace std;
#define Nmax 2000000/2+1
int N, contor;
char (*p) = new char [Nmax];
void citire(){
freopen("ciur.in", "r", stdin);
scanf("%d", &N);
}
void gen(){
contor = 1;
for(int i = 1; ( ( i * i ) << 1 ) + ( i << 1 ) <= N; ++i)
if( ( p[ i >> 3] & ( 1 << ( i & 7 ) ) ) == 0){
for(int j = ( ( i * i ) << 1 ) + ( i << 1 ); (j << 1) + 1 <= N; j += (i << 1) + 1)
p[ j >> 3 ] |= ( 1 << ( j & 7 ) );
}
for(int i = 1; ( i << 1 ) + 1 <= N; ++i)
if( (p[ i >> 3] & ( 1 << ( i & 7 ) ) ) == 0)
contor++;
}
void afis(){
freopen("ciur.out", "w", stdout);
printf("%d\n", contor);
}
int main(){
citire();
gen();
afis();
return 0;
}