Cod sursa(job #2610658)

Utilizator michael_blazemihai mihai michael_blaze Data 5 mai 2020 12:29:18
Problema Ciurul lui Eratosthenes Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.54 kb
#include <cstdio>
#include <cmath>

using namespace std;

bool prime[2000005];

// 1 - daca nu este prim
// 0 - daca este prim

int main() {
	freopen("ciur.in", "r", stdin);
	freopen("ciur.out", "w", stdout);

	int N;

	scanf("%d", &N);

	int SQRT = sqrt(N);

	prime[1] = 1;
	int counter = 0;

	for (int i = 2;i <= SQRT;i ++) {
		if (!prime[i]) {
			for (int j = i + i;j <= N;j += i) {
				prime[j] = 1;
			}
		}
	}

	for (int i = 1;i <= N;i ++)
		if (!prime[i])
			counter ++;

	printf("%d", counter);
	return 0;
}