Cod sursa(job #2610665)

Utilizator michael_blazemihai mihai michael_blaze Data 5 mai 2020 12:40:43
Problema Ciurul lui Eratosthenes Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.49 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);

	prime[1] = 1;
	int counter = N - 1;

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

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