Cod sursa(job #2723358)

Utilizator Razvan48Capatina Razvan Nicolae Razvan48 Data 13 martie 2021 22:25:31
Problema Ciurul lui Eratosthenes Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.69 kb
#include <fstream>
#include <bitset>
using namespace std;

const int NMAX=2000000;

bitset <1+NMAX> prim;

void initiereCiur()
{
    int i,j;
    prim[0]=1;
    prim[1]=1;
    for(i=4;i<=NMAX;i=i+2)
    {
        prim[i]=1;
    }
    for(i=3;i*i<=NMAX;i=i+2)
    {
        if(prim[i]==0)
        {
            for(j=2*i;j<=NMAX;j=j+i)
            {
                prim[j]=1;
            }
        }
    }
}

int main()
{
    ifstream f("ciur.in");
    ofstream g("ciur.out");

    int n,nr=0;
    f>>n;

    initiereCiur();

    for(int i=2;i<=n;i++)
    {
        if(prim[i]==0)
        {
            nr++;
        }
    }

    g<<nr;

    return 0;
}