Cod sursa(job #3182173)

Utilizator TeodorVTeodorV TeodorV Data 8 decembrie 2023 18:29:57
Problema Ciurul lui Eratosthenes Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.57 kb
#include <bits/stdc++.h>

using namespace std;

ifstream fin("ciur.in");
ofstream fout("ciur.out");

const int Nmax=2000001;

bitset<Nmax> ciur;
void initciur()
{
    ciur[0]=ciur[1]=1;
    for(int i=4; i<Nmax; i+=2)
        ciur[i]=1;
    for(int i=3; i*i<Nmax; i+=2)
    {
        if(ciur[0]==1)
        {
            for(int j=i*i; j<Nmax; j+=i)
                ciur[j]=1;
        }
    }
}

int main()
{
    initciur();
    int n;
    fin>>n;
    int cnt=0;
    for(int i=2; i<=n; i++)
        cnt+=(!ciur[i]);
    fout<<cnt;
    return 0;
}