Cod sursa(job #2504033)

Utilizator lucamLuca Mazilescu lucam Data 4 decembrie 2019 11:34:07
Problema Ciurul lui Eratosthenes Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.51 kb
#include <bitset>
#include <cstdio>

const int NMAX = 2 * 1e6 - 2;
std::bitset<NMAX> ciur;

int main()
{
    freopen("ciur.in", "r", stdin);
    freopen("ciur.out", "w", stdout);
    int n;
    scanf("%d", &n);
    for (int i = 2; i * i <= n; ++i)
        if (!ciur[i - 2])
            for (int j = i; i * j <= n; ++j)
                ciur[i * j - 2] = true;
    int cnt = 0;
    for (int i = 2; i <= n; ++i)
        if (!ciur[i - 2])
            ++cnt;
    printf("%d\n", cnt);
    fclose(stdin);
    fclose(stdout);
}