Nu aveti permisiuni pentru a descarca fisierul grader_test6.ok
Cod sursa(job #3158823)
| Utilizator | Data | 19 octombrie 2023 21:07:34 | |
|---|---|---|---|
| Problema | Ciurul lui Eratosthenes | Scor | 70 |
| Compilator | cpp-64 | Status | done |
| Runda | Arhiva educationala | Marime | 0.74 kb |
#include <bits/stdc++.h>
#include <unordered_map>
using namespace std;
#define ll long long
#define ull unsigned long long
#define nmax 2000006
#define MOD 9901
#define INF 2123456789
//#define fin cin
//#define fout cout
ifstream fin("ciur.in");
ofstream fout("ciur.out");
int p[nmax];
void Ciur(int n)
{
p[0] = p[1] = 1; // marcam cu 1 elementele NEprime
for (int i = 4; i <= n; i += 2)
p[i] = 1;
for (int i = 3; i * i <= n; i += 2)
if (!p[i]) // daca se crede prim
for (int j = i * i; j <= n; j += 2 * i)
p[j] = 1;
}
int main()
{
int i, n, cnt;
fin >> n;
Ciur(n);
cnt = 0;
for (i = 1; i <= n; i++)
if (!p[i])
++cnt;
fout << cnt << "\n";
fin.close();
fout.close();
return 0;
}