Pagini recente » Cod sursa (job #1568028) | Cod sursa (job #2987827) | Cod sursa (job #2302811) | Cod sursa (job #3137338) | Cod sursa (job #1451995)
#include <stdio.h>
#define MAX_N 1000000
int phi[MAX_N + 1]; // phi[i] = numarul de nr <= n si prime cu acesta
void genPhi(int n) {
for (int i = 1; i <= n; i++) {
phi[i] = i;
}
for (int i = 2; i <= n; i++) {
if (phi[i] == i) {
for (int j = i; j <= n; j += i) {
phi[j] = phi[j] - phi[j] / i;
}
}
}
}
int main(void) {
FILE *f = fopen("fractii.in", "r");
int n;
int s;
fscanf(f, "%d", &n);
fclose(f);
genPhi(n);
s = 0;
for (int i = 1; i <= n; i++) {
s += phi[i];
}
f = fopen("fractii.out", "w");
fprintf(f, "%d\n", 2 * s - 1); // o pereche de 2 numere prime intre ele determina 2 fractii ireductibile diferite, inafara de 1/1
fclose(f);
return 0;
}