Pagini recente » Cod sursa (job #2782161) | Cod sursa (job #2979209) | Cod sursa (job #3215157) | Cod sursa (job #1941902) | Cod sursa (job #1042782)
#include<stdio.h>
#include<math.h>
unsigned char ciur[((2000000>>4)+2)];
int eratostenes(int n){
int i,j;
int prime=(n+1)/2;
for(i=3;i*i<=n;i+=2){
if(ciur[i>>4]&(1<<((i>>1)&7)))
continue;
for(j=i*3;j<=n;j+=i+i){
if(!(ciur[j>>4]&(1<<((j>>1)&7))))
prime--;
ciur[j>>4]|=(1<<((j>>1)&7));
}
}
return prime;
}
int main(){
int n;
freopen("ciur.in","r",stdin);
freopen("ciur.out","w",stdout);
scanf("%d",&n);
printf("%d",eratostenes(n));
return 0;
}