Cod sursa(job #2788188)

Utilizator tudorcohalTudor Cohal tudorcohal Data 25 octombrie 2021 11:27:52
Problema Ciurul lui Eratosthenes Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.77 kb
#include <fstream>
#include <bitset>

using namespace std;

const int NMAX = 2e6;

//bitset <>
bool c[1+NMAX];

int main()
{
    ifstream in("ciur.in");
    ofstream out("ciur.out");
    int n;
    in >> n;
    in.close();
    for(int i = 2; i * i <= n ; i++)///parcurg numerele ale caror multiplii nu pot fi nemarcati si mai mici ca n
    {
        if (!c[i])///daca i este prim
        {
            for(int j = i * i; j <= n; j += i)///parcurgem multiplii lui i
            {
                c[j] = true;
            }
        }
    }
    int nr = 0;///nr. de numere prime mai mici sau egale cu n
    for (int i = 2; i <= n;i++)
    {
        if(!c[i])
        {
            nr++;
        }
    }
    out << nr;
    out.close();

    return 0;
}