Cod sursa(job #2600295)

Utilizator cristia_razvanCristia Razvan cristia_razvan Data 12 aprilie 2020 13:28:38
Problema Ciurul lui Eratosthenes Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.5 kb
#include <bits/stdc++.h>
using namespace std;

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

int n;
bitset<2000001> prim;


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

int main()
{
	int cnt = 0;
	fin >> n;
	ciur(n);
	for (int i = 2; i <= n; i++)
		if (!prim[i])
			cnt++;
	fout << cnt << "\n";
	fin.close();
	fout.close();
	return 0;
}