Pagini recente » Cod sursa (job #2805713) | Cod sursa (job #500155) | Cod sursa (job #1289565) | Cod sursa (job #1889610) | Cod sursa (job #1042759)
#include<stdio.h>
#include<math.h>
char ciur[((2000000>>4)+2)];
int eratostenes(int n){
int i,j;
int prime=n/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;
}