Pagini recente » Cod sursa (job #2184457) | Monitorul de evaluare | Cod sursa (job #2044380) | Cod sursa (job #2509931) | Cod sursa (job #1556326)
#include <iostream>
#include <cstdio>
#include <vector>
#include <algorithm>
#include <cmath>
using namespace std;
int main()
{
freopen("ciur.in", "r", stdin);
freopen("ciur.out", "w", stdout);
int n;
cin >> n;
vector<bool> sieve(n+1, true);
sieve[0] = false;
sieve[1] = false;
for (int i = 2; i <= sqrt(n); i++) {
if (!sieve[i]) continue;
for (int j = i*i; j <= n; j += i) {
sieve[j] = false;
}
}
printf("%d\n", count(sieve.begin(), sieve.end(), true));
}