Pagini recente » Rating Lionel Geo Mischie (liogeo) | Cod sursa (job #2921290) | Cod sursa (job #166518) | Cod sursa (job #3166914) | Cod sursa (job #767285)
Cod sursa(job #767285)
#include <cstdio>
#include <cmath>
#include <cstring>
using namespace std;
int n;
void ciur(){
unsigned char p[n/8+1];
memset(p,0,sizeof(p));
int i = 2, l = sqrt(n);
while(i <= l)
{
while( p[i/8]&(1<<(i%8)) )i++;
for(int j=i*i;j<=n;j+=i) p[j/8] |= 1<<(j%8);
i++;
}
int nr = 0;
for(int i=2;i<=n;i++)
if( !(p[i/8]&(1<<(i%8))) ) nr++;
printf("%d\n",nr);
}
int main(){
freopen("ciur.in","r",stdin);
freopen("ciur.out","w",stdout);
scanf("%d",&n);
ciur();
return 0;
}