Pagini recente » Cod sursa (job #1903221) | Cod sursa (job #549354) | Cod sursa (job #2248075) | Cod sursa (job #2566737) | Cod sursa (job #1418393)
#include <iostream>
#include <fstream>
#include <string>
#include <stdlib.h>
#include <string.h>
#define MAX 100005;
int phi[100005];
using namespace std;
const char *in_file_name = "sum.in";
const char *out_file_name = "sum.out";
void die(bool assertion, const char *message)
{
if (assertion) {
fprintf(stderr, "(%s, %d): ",__FILE__, __LINE__);
perror(message);
exit(EXIT_FAILURE);
}
}
void set_phi()
{
int N = MAX;
for (int i = 1; i < N; i++)
phi[i] = i - 1;
for (int i = 2; i < N; i++)
for (int j = i+i; j < N; j += i)
phi[j] -= phi[i];
}
int main()
{
int N, x;
string line;
ifstream in_file;
FILE *out;
in_file.open(in_file_name, ios::in);
die(!in_file, "Error opening file for reading");
out = fopen(out_file_name, "w");
getline(in_file, line);
N = atoi(line.c_str());
set_phi();
for (int i = 0; i < N; i++) {
getline(in_file, line);
x = atoi(line.c_str());
fprintf(out, "%lld\n", 2LL * phi[x] * x);
}
in_file.close();
fclose(out);
return 0;
}