#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <ctype.h>
#define MAX 10
int contas_validas = 0;
int contas_invalidas = 0;
typedef struct conta {
char saldo[1000000];
char limite_saldo[1000000];
char id[11];
struct conta * prox;
} Conta;
typedef struct movimento {
int tipo_movimento;
int opcao;
} Movimento;
int validar_id(char* id){
if (id[3] == '-' && id[9] == '-' && id[11] == '\0'){
int i = 0;
for(i = 0; i < 11; i++){
if(i != 3 && i != 9){
return 0;
}
}
}
}
else{
return 0;
}
return 1;
}
int validar_id2 (char* id) {
int componente_a = ((id[0]-'0')+ (id[1]-'0')+(id[2]-'0'));
int componente_b = ((id[4]-'0')+ (id[5]-'0')+(id[6]-'0')+(id[7]-'0')+(id[8]-'0'));
int componente_c = (id[10]-'0');
int soma1 = componente_a;
int soma2 = componente_a + componente_b;
int resto = soma2 % soma1;
if (resto == componente_c) {
return 1;
}
else {
return 0;
}
}
int validar_saldo(char *str) {
fprintf(stderr
, "DEBUG: valor passado: [%s]\n", str
); if (*str == '-') str++;
if (!isdigit((unsigned char)*str
)) return 0; /* empty strings return false */ while (*str) {
if (!isdigit((unsigned char)*str
)) return 0; str++;
}
return 1;
}
int validar_limite(char* str){
int i=1;
for(i = 1; str[i]!='\0' ; i++){
return 0;
}
}
}
return 1;
}
int validar_movimento (char * mov){
if (mov[0] == 0){
}
else if (mov[0] == 1){
}
else if (mov[0] == 2){
}
else{
return 0;
}
return 0;
}
void transferencia ( Conta* a , char id[] , char id2[] , char valor[] ){
int i=0;
int j=0;
int valor1;
int valor2;
for ( i; i<contas_validas ; i++){
if(strcmp( a
[i
].
id , id
) == 0) break;
}
for ( j ; j<contas_validas ; j++){
if(strcmp( a
[j
].
id , id2
) == 0) break;
}
valor1
= atoi(a
[i
].
saldo); valor2
= atoi(a
[j
].
saldo);
snprintf( a
[i
].
saldo , sizeof(a
[i
].
saldo) , "%d" , valor1
); snprintf( a
[j
].
saldo , sizeof(a
[j
].
saldo) , "%d" , valor2
); }
void deposito ( Conta* a , char id[] , char valor[] ){
int valor1;
int i=0;
for ( i ; i<contas_validas ; i++ ){
if(strcmp( a
[i
].
id , id
) == 0) break;
}
valor1
= atoi(a
[i
].
saldo); snprintf( a
[i
].
saldo , sizeof(a
[i
].
saldo) , "%d" , valor1
); }
void levantamento ( Conta* a , char id[] , char valor[] ){
int valor1;
int i=0;
for ( i ; i<contas_validas ; i++ ){
if(strcmp( a
[i
].
id , id
) == 0) break;
}
valor1
= atoi(a
[i
].
saldo); snprintf( a
[i
].
saldo , sizeof(a
[i
].
saldo) , "%d" , valor1
); }
/* ATENÇÃO!!!!!!!!!!!!!!!!!!!
void movimentos (){
FILE * fp = fopen ("movimentos.txt", "r");
if (fp != NULL){
char temp[255+1];
char * componentes;
int contador = 0;
char id_origem[11];
char id_destino[11]
char valor[1000000];
while (fgets(temp, 255+1, fp) != NULL){
printf ("\n-> %s\n\n", temp);
contador = 0;
int last = strlen (temp);
if (temp[last-1] == '\n')
temp[last-1] = '\0';
componentes = strtok (temp, " ");
/* FALTA MERDAS
if (contador == 0 ){
int i = 0;
transferencia(guarda_conta , id_origem , id_destino , valor);
}
else if(contador == 1){
deposito();
}
else if(contador == 2{
levantamento();
}
}
fclose(fp);
}
}
*/
void contas (Conta* a){
FILE
* fp
= fopen ("contas.txt", "r"); //"r" -> leitura (modo texto) ou "b" -> leitura (modo binario) FILE
* fp2
= fopen ("stats.txt", "w");
if (fp != NULL){
char tmpid[11];
char tmpsaldo[1000000];
char tmplimitecredito[1000000];
char contas[255+1];
char* temp_id[11+1];
char* componentes;
int contador = 0;
int val1;
int val2;
int val3;
printf ("As contas existentes no ficheiro sao:\n");
while (fgets(contas
, 255+1, fp
) != NULL
){ printf ("\n-> %s\n\n", contas
); contador = 0;
if (contas[last-1] == '\n')
contas[last-1] = '\0';
componentes
= strtok (contas
, " ");
while (componentes != NULL){
if (contador == 0) {
printf ("- ID = %s\n", componentes
); int valido = validar_id (componentes);
int valido2 = validar_id2 (componentes);
if (valido == 1 && valido2 == 1){
val1 = 1;
}
else {
val1 = 0;
}
}
else if (contador == 1){
strcpy(tmpsaldo
, componentes
); int valido = validar_saldo(componentes);
if (valido == 1){
printf ("- Saldo: %s\n", componentes
); val2 = 1;
}
else{
val2 = 0;
}
}
else if (contador == 2){
strcpy(tmplimitecredito
, componentes
); int valido = validar_limite(componentes);
/* ATENÇÂO AO FACTO DE NÃO HAVER COMPONENTE) */
if (valido == 1){
printf ("- Limite de credito: %s\n", componentes
); val3 = 1;
}
else{
printf ("Limite de credito invalido!\n"); val3 = 0;
}
}
componentes
= strtok (NULL
, " "); contador++;
}
if (val1 == 1 && val2 == 1 && val3 == 1){
strcpy(a
[contas_validas
].
id , tmpid
); strcpy(a
[contas_validas
].
saldo , tmpsaldo
); strcpy(a
[contas_validas
].
limite_saldo , tmplimitecredito
); contas_validas++;
if((contas_validas%MAX)==0){
Conta* ptr;
ptr
=(Conta
*)realloc(a
,sizeof(Conta
)*(contas_validas
+MAX
)); if(ptr!=NULL){
a=ptr;
ptr=NULL;
}
}
}
else if (val1 == 0 || val2 == 0 || val3 == 0){
contas_invalidas++;
}
}
printf ("\nNumero de contas validas: %d\n", contas_validas
); printf ("\nNumero de contas invalidas: %d\n", contas_invalidas
); }
else{
}
}
/*
int compara_conta (Conta * c1, Conta * c2) {
if (c1 -> saldo > c2 -> saldo)
return 1;
if (c1 -> saldo = c2 -> saldo)
return 0;
if (c1 -> saldo < c2 -> saldo)
return -1;
}
*/
int main() {
FILE
* fp
= fopen("contas-final.txt" , "w+"); Conta
* guardar_conta
=(Conta
*)malloc(sizeof(Conta
)*MAX
); contas(guardar_conta);
long int somatorioInicial = 0;
int i = 0;
for ( i ; i< contas_validas ; i++){
somatorioInicial
+= atoi(guardar_conta
[i
].
saldo); }
printf("\n%d", somatorioInicial
); /* ATENÇÂO AO COMENTÁRIO DE CIMA */ /* movimentos(); */
int n;
for ( n=0 ; n<contas_validas ; n++){
fprintf(fp
, "%s %s %s\n" , guardar_conta
[n
].
id , guardar_conta
[n
].
saldo ,guardar_conta
[n
].
limite_saldo); }
return 0;
}
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <ctype.h>
#define MAX 10

int contas_validas = 0;
int contas_invalidas = 0;

typedef struct conta {
    char saldo[1000000];
    char limite_saldo[1000000];
    char id[11];
    struct conta * prox;
} Conta;

typedef struct movimento {
    int tipo_movimento;
    int opcao;
} Movimento;

int validar_id(char* id){

    if (id[3] == '-' && id[9] == '-' && id[11] == '\0'){

			int i = 0;

			for(i = 0; i < 11; i++){
				if(i != 3 && i != 9){
					if(isdigit(id[i]) == 0){
						return 0;
					}
				}
			}
	}
	else{
		return 0;
	}
	return 1;
}

int validar_id2 (char* id) {

    int componente_a = ((id[0]-'0')+ (id[1]-'0')+(id[2]-'0'));
    int componente_b = ((id[4]-'0')+ (id[5]-'0')+(id[6]-'0')+(id[7]-'0')+(id[8]-'0'));
    int componente_c = (id[10]-'0');

    int soma1 = componente_a;
    int soma2 = componente_a + componente_b;
    int resto = soma2 % soma1;

    if (resto == componente_c) {
        return 1;
    }
	else {
        return 0;
    }
}

int validar_saldo(char *str) {
	fprintf(stderr, "DEBUG: valor passado: [%s]\n", str);
    if (*str == '-') str++;
    if (!isdigit((unsigned char)*str)) return 0; /* empty strings return false */
    while (*str) {
        if (!isdigit((unsigned char)*str)) return 0;
        str++;
    }
    return 1;
}

int validar_limite(char* str){
	if(isdigit(str[0]) == 1){
		int i=1;
		for(i = 1; str[i]!='\0' ; i++){
			if(isdigit(str[i])==0){
				return 0;
			}
		}
	}
	return 1; 
}

int validar_movimento (char * mov){
    if (mov[0] == 0){
        printf ("Transferencia.\n");
    }
	else if (mov[0] == 1){
        printf ("Deposito.\n");
    }
	else if (mov[0] == 2){
        printf ("Levantamento.\n");
    }
	else{
        return 0;
    }
    return 0;
}

void transferencia ( Conta*  a , char id[] , char id2[] , char valor[] ){
	int i=0;
	int j=0;
	int valor1;
	int valor2;
 
	for ( i; i<contas_validas ; i++){
		if(strcmp( a[i].id , id ) == 0)
			break;
	}
 
	for ( j ; j<contas_validas ; j++){
		if(strcmp( a[j].id , id2) == 0)
			break;
	}
 
	valor1 = atoi(a[i].saldo);
	valor1 -= atoi(valor);
	valor2 = atoi(a[j].saldo);
	valor2 += atoi(valor);
 
	snprintf( a[i].saldo , sizeof(a[i].saldo) , "%d" , valor1);
	snprintf( a[j].saldo , sizeof(a[j].saldo) , "%d" , valor2);
}

void deposito ( Conta* a , char id[] , char valor[] ){
	int valor1;
	int i=0;
	
	for ( i ; i<contas_validas ; i++ ){
		if(strcmp( a[i].id , id ) == 0)
		break;
	}

	valor1 = atoi(a[i].saldo);
	valor1 += atoi(valor);
	snprintf( a[i].saldo , sizeof(a[i].saldo) , "%d" , valor1);
}

void levantamento ( Conta* a , char id[] , char valor[] ){
	int valor1;
	int i=0;

	for ( i ; i<contas_validas ; i++ ){
		if(strcmp( a[i].id , id ) == 0)
			break;
	}

	valor1 = atoi(a[i].saldo);
	valor1 -= atoi(valor);
	snprintf( a[i].saldo , sizeof(a[i].saldo) , "%d" , valor1);
}
 /* ATENÇÃO!!!!!!!!!!!!!!!!!!!
void movimentos (){

    FILE * fp = fopen ("movimentos.txt", "r");

    if (fp != NULL){

		char temp[255+1];
        char * componentes;
        int contador = 0;
		char id_origem[11];
		char id_destino[11]
		char valor[1000000];

        while (fgets(temp, 255+1, fp) != NULL){
			printf ("\n-> %s\n\n", temp);
			contador = 0;
			
			int last = strlen (temp);
            if (temp[last-1] == '\n')
				temp[last-1] = '\0';
				
            componentes = strtok (temp, " ");
			/* FALTA MERDAS 
			
			if (contador == 0 ){
				int i = 0;
				transferencia(guarda_conta , id_origem , id_destino , valor);
			}
			else if(contador == 1){
					deposito();
			}
			else if(contador == 2{
					levantamento();
			}
		}   
        
        fclose(fp);
    }
}
*/
void contas (Conta* a){

	FILE* fp = fopen ("contas.txt", "r"); //"r" -> leitura (modo texto) ou "b" -> leitura (modo binario)
	FILE* fp2 = fopen ("stats.txt", "w");


    if (fp != NULL){

			char tmpid[11];
			char tmpsaldo[1000000];
			char tmplimitecredito[1000000];
            char contas[255+1];
            char* temp_id[11+1];
            char* componentes;
            int contador = 0;
            int val1;
            int val2;
            int val3;

            printf ("As contas existentes no ficheiro sao:\n");

            while (fgets(contas, 255+1, fp) != NULL){
				printf ("\n-> %s\n\n", contas);
                contador = 0;

                int last = strlen (contas);
                if (contas[last-1] == '\n')
                    contas[last-1] = '\0';

				componentes = strtok (contas, " ");

				while (componentes != NULL){

					if (contador == 0) {

						printf ("- ID = %s\n", componentes);
						strcpy(tmpid , componentes);
						int valido = validar_id (componentes);
						int valido2 = validar_id2 (componentes);

						if (valido == 1 && valido2 == 1){
							printf ("ID valido!\n");
							val1 = 1;
						}
						else {
							printf ("ID invalido!\n");
							val1 = 0;
						}
					}
					else if (contador == 1){
						strcpy(tmpsaldo , componentes);
						int valido = validar_saldo(componentes);
						if (valido == 1){
							printf ("- Saldo: %s\n", componentes);
							val2 = 1;
						}
						else{
							printf ("Saldo invalido!\n");
							val2 = 0;
						}
					}
					else if (contador == 2){
						strcpy(tmplimitecredito , componentes);
						int valido = validar_limite(componentes);
						/* ATENÇÂO AO FACTO DE NÃO HAVER COMPONENTE) */
						if (valido == 1){
							printf ("- Limite de credito: %s\n", componentes);
							val3 = 1;
						}
						else{
							printf ("Limite de credito invalido!\n");
							val3 = 0;
						}
					}

					componentes = strtok (NULL, " ");
					contador++;

				}

				if (val1 == 1 && val2 == 1 && val3 == 1){

						strcpy(a[contas_validas].id , tmpid);
						strcpy(a[contas_validas].saldo , tmpsaldo);
						strcpy(a[contas_validas].limite_saldo , tmplimitecredito);
						contas_validas++;
						if((contas_validas%MAX)==0){
							Conta* ptr;
							ptr=(Conta*)realloc(a,sizeof(Conta)*(contas_validas+MAX));
							if(ptr!=NULL){
								a=ptr;
								ptr=NULL;
							}
						}
				}
				else if (val1 == 0 || val2 == 0 || val3 == 0){
                    contas_invalidas++;
				}
            }
			
			fclose(fp);

			printf ("\nNumero de contas validas: %d\n", contas_validas);
			printf ("\nNumero de contas invalidas: %d\n", contas_invalidas);
    }
    else{
		printf ("Erro!\n");
    }
}
/*
int compara_conta (Conta * c1, Conta * c2) {
        if (c1 -> saldo > c2 -> saldo)
            return 1;
        if (c1 -> saldo = c2 -> saldo)
            return 0;
        if (c1 -> saldo < c2 -> saldo)
            return -1;
}
*/
int main() {

	FILE * fp = fopen("contas-final.txt" , "w+");
	Conta* guardar_conta=(Conta*)malloc(sizeof(Conta)*MAX);
    contas(guardar_conta);
	long int somatorioInicial = 0;
	int i = 0;
	for ( i  ; i< contas_validas ; i++){
       somatorioInicial += atoi(guardar_conta[i].saldo);
	}
	printf("\n%d", somatorioInicial); /* ATENÇÂO AO COMENTÁRIO DE CIMA */
    printf("\n");
 /*   movimentos(); */
	int n;
	for ( n=0 ; n<contas_validas ; n++){
		fprintf(fp , "%s %s %s\n" , guardar_conta[n].id , guardar_conta[n].saldo ,guardar_conta[n].limite_saldo);
	}
	fclose(fp);

    return 0;
}