Cod sursa(job #2704696)
Utilizator | Andrei Catineanu Andrei_c765 | Data | 10 februarie 2021 23:31:14 |
---|---|---|---|
Problema | Ciurul lui Eratosthenes | Scor | 100 |
Compilator | cpp-64 | Status | done |
Runda | Arhiva educationala | Marime | 0.58 kb |
#include <iostream>
#include<fstream>
#include <cstring>
#include <algorithm>
#include <cmath>
#include <bitset>
#include <climits>
using namespace std;
ifstream fin("ciur.in");
ofstream fout("ciur.out");
bitset <2000010> p;
int eratostene(int n)
{
int k = 0;
p[0] = p[1] = 1;
for (int i = 2; i <= n; i++)
{
if (p[i] == 0)
{
k++;
for (int j = 2*i; j <= n; j += i)
p[j] = 1;
}
}
return k;
}
int main()
{
int n;
fin >> n;
fout << eratostene(n);
}