Cod sursa(job #2606521)
Utilizator | Data | 27 aprilie 2020 22:05:07 | |
---|---|---|---|
Problema | Ciurul lui Eratosthenes | Scor | 30 |
Compilator | cpp-64 | Status | done |
Runda | Arhiva educationala | Marime | 0.49 kb |
#include <iostream>
#include <fstream>
using namespace std;
typedef pair<int, int> directie;
ifstream f("ciur.in");
ofstream g("ciur.out");
bool prim[2000002];
int n;
int main()
{
f >> n;
fill(prim + 1, prim + n + 1, true);
int nr = 0;
for (int i = 2;i <= n;i++)
{
if (prim[i])
{
for (int j = i * i;j <= n;j += i)
prim[j] = false;
nr++;
}
}
g << nr;
f.close();
g.close();
}