Cod sursa(job #2466987)
Utilizator | Data | 3 octombrie 2019 14:45:25 | |
---|---|---|---|
Problema | Ciurul lui Eratosthenes | Scor | 100 |
Compilator | cpp-64 | Status | done |
Runda | Arhiva educationala | Marime | 0.45 kb |
#include <bits/stdc++.h>
using namespace std;
#define MaxN 2000000
char prime[MaxN + 1];
int N;
int main() {
freopen("ciur.in", "r", stdin);
freopen("ciur.out", "w", stdout);
int i, j, res = 0;
cin >> N;
for(i = 2; i * i <= N; i++)
if(!prime[i])
for(j = i * i; j <= N; j = j + i) prime[j] = 1;
for(i = 2; i <= N; i++) res = res + (prime[i] == 0);
cout << res;
return 0;
}