Cod sursa(job #1355493)

Utilizator Marian_25Stanciulica Marian Marian_25 Data 22 februarie 2015 19:19:03
Problema Convertor Scor 100
Compilator c Status done
Runda rosedu_cdl_2015 Marime 1.58 kb
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<ctype.h>

int main()
{
	FILE *input, *output;
	int i = 0, MAX = 30000000;
	
	input = fopen("convertor.in", "r");
	output = fopen("convertor.out", "w");
	
	char c;
	char *str;
	
	str = malloc(MAX * sizeof(char));
	if(str == NULL)
	{
		printf("Error alocating memory!");
		exit(1);
	}
	
	char a = getc(input);
	int nr_quotes = 0;
	
	if(input)
	{
		while((c = getc(input)) != EOF)
		{
			if(c == '\"')
			{
				nr_quotes++;
			}
			if (nr_quotes % 2 == 1)
			{
				str[i] = c;
				i++;
			}
			else if(isdigit(c) != 0 && isdigit(a) == 0 && nr_quotes % 2 == 0)
			{
				str[i] = '\"';
				i++;
				str[i] = c;
				i++;
			}
			else if (isdigit(c) != 0 && nr_quotes % 2 == 0)
			{
				str[i] = c;
				i++;
			}
			a = c;
		}
	}
	str[i] = '\0';
	
	char **mat, *p;
	
	i = 1;
	int	nr = 1;

	mat = malloc(strlen(str) * sizeof(char));

	if(mat == NULL)
	{
		printf("Error alocating memory!");
		exit(1);
	}

	mat[0] = strtok(str, "\"");
	while((p = strtok(NULL, "\"")) != NULL)
	{
		mat[i] = p;
		i++;
		nr++;
	}
	
	int nr_camp = 1;
	for(i = 2; i < nr; i = i + 2)
	{
		if(strcmp(mat[0], mat[i]) == 0)
				break;
		nr_camp++;
	}
	
	for(i = 0; i < nr_camp * 2; i += 2)
	{
		fprintf(output, "%s,", mat[i]);
	}
	fprintf(output, "\n");
	
	for(i = 1; i < nr; i += 2)
	{
		fprintf(output, "%s,", mat[i]);
		
		if((i+1) % (nr_camp*2) == 0 && i < nr - nr_camp*2)
			fprintf(output,"\n");
	}
	
	fclose(input);
	fclose(output);

	free(mat);
	free(str);
	return 0;
}