Cod sursa(job #1418375)

Utilizator MarianVasilcaMarian Vasilca MarianVasilca Data 12 aprilie 2015 21:24:34
Problema Sum Scor 70
Compilator cpp Status done
Runda Arhiva de probleme Marime 1.33 kb
#include <iostream>
#include <fstream>
#include <string>
#include <stdlib.h>
#include <string.h>

#define MAX 100005; 
int phi[100010];

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 = 0; i <=N; i++)
		phi[i] = 0;

	for (int i = 1; i <= N; i++)
		phi[i] = i - 1;

	for (int i = 2; i <= N; i++)
		for (int j = 2*i; j <= N; j += i)
			phi[j] -= phi[i];

}


int main()
{
	int N, x, offset = 0;
	char *results;
	char buffer[1000];

	string line;
	ifstream in_file;
	ofstream out_file;

	in_file.open(in_file_name, ios::in);
	die(!in_file, "Error opening file for reading");

	out_file.open(out_file_name, ios::out);
	die(!out_file, "Error opening file for writing");

	getline(in_file, line);
	N = atoi(line.c_str());

	set_phi();

	results = new char[100*N+10];

	for (int i = 0; i < N; i++) {

		getline(in_file, line);
		x = atoi(line.c_str());

		memset(&buffer[0], 0, sizeof(buffer));

		sprintf(buffer, "%lld\n", phi[x]*2*x*1LL);
		sprintf(results + offset, "%s", buffer);

		offset += strlen(buffer);

	}

	out_file << results;

	in_file.close();
	out_file.close();

	delete []results;

	return 0;
}