Pagini recente » Cod sursa (job #2983915) | Cod sursa (job #108251) | Cod sursa (job #279787) | Cod sursa (job #672872) | Cod sursa (job #2662901)
#include <iostream>
#include <cstdio>
using namespace std;
const int NMAX = 2000000;
const int BASE = 64;
long long ciur[NMAX / BASE + 1];
int main() {
freopen("ciur.in", "r", stdin);
freopen("ciur.out", "w", stdout);
int n, ans = 0;
scanf("%d", &n);
ciur[0] = 3;
for(int i = 2; i <= n; i++)
if(!( ciur[i / BASE] & (1 << (i % BASE)) )) {
ans++;
for(int j = 2 * i; j <= n; j += i)
ciur[j / BASE] |= (1 << (j % BASE));
}
printf("%d", ans);
return 0;
}