Pagini recente » Cod sursa (job #799706) | Cod sursa (job #1258078) | Cod sursa (job #107116) | Cod sursa (job #768647) | Cod sursa (job #2972477)
#include <iostream>
#include <fstream>
#include <cstring>
#define NMAX 2000001
using namespace std;
ifstream fin("ciur.in");
ofstream fout("ciur.out");
int SieveOfEratosthenes(int n)
{
int cnt=0;
bool prime[NMAX];
memset(prime, true, sizeof(prime));
for (int p = 2; p * p <= n; p++) {
if (prime[p] == true) {
for (int i = p * p; i <= n; i += p)
prime[i] = false;
}
}
for (int p = 2; p <= n; p++)
if (prime[p])
cnt++;
return cnt;
}
int main(){
int n;
fin>>n;
fout<<SieveOfEratosthenes(n);
return 0;
}