#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <ctype.h>
#define MAX 10
int contas_validas = 0;
int contas_invalidas = 0;
int movimentos_validos = 0;
int movimentos_invalidos =0;
typedef struct conta {
char saldo[1000000];
char limite_saldo[1000000];
char id[11];
} 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 is_valid_n_chars(char * string, size_t size, char * chars) {
int sindex = 0, cindex = 0;
// ciclo de validação da string dada
while(sindex < size && string[sindex] != '\0') {
// pesquisa do caracter iterado na lista de caracteres válidos
for (cindex = 0;
chars[cindex] != '\0' && string[sindex] != chars[cindex];
cindex++) /* void */;
// verificação se o caracter foi encontrado
if (chars[cindex] == '\0')
return 0;
// incremento da iteração
sindex++;
}
// é válido se chegou ao fim da string com todos os caracteres validados
// (verificação de string[sindex] == '\0' mas sindex < size)
return sindex == size;
}
int is_valid_chars(char * string, char * chars) {
return is_valid_n_chars
(string
, strlen(string
), chars
); }
int is_valid_n_number(char * string, size_t size) {
return is_valid_n_chars(string, size, "0123456789");
}
int is_valid_number(char * string) {
return is_valid_n_number
(string
, strlen(string
)); }
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
); }
int valida_opcao_mov ( char a[])
{
if ( a[0] == '0' || a[0] == '1' || a[0] == '2')
return 1;
else
return 0;
}
void movimentos (Conta* guardar_conta)
{
FILE
* fp
= fopen ("movimentos.txt", "r");
if (fp != NULL)
{
char temp[255+1];
char * componentes;
int contador = 0;
char operacao[1];
char id_origem[11];
char id_destino[11];
char valor[1000000];
while (fgets(temp
, 255+1, fp
) != NULL
) {
contador = 0;
if (temp[last-1] == '\n')
temp[last-1] = '\0';
componentes
= strtok (temp
, " ");
while (componentes != NULL)
{
if (contador == 0 )
{
strcpy(operacao
, componentes
); valida_opcao_mov ( operacao );
}
else if(contador == 1)
{
strcpy( id_origem
, componentes
); }
else if(contador == 2)
{
if ( operacao[0] == '0')
strcpy(id_destino
, componentes
); if ( operacao[0] == '1' || operacao[0] == '2' )
strcpy( valor
, componentes
); }
else if( contador== 3)
{
if ( operacao[0] == '0')
strcpy( valor
, componentes
); else
{
printf( "Movimento invalido\n"); movimentos_invalidos++;
}
}
componentes
= strtok (NULL
, " "); contador++;
}
if ( operacao[0] == '0' )
transferencia( guardar_conta , id_origem , id_destino , valor);
if ( operacao[0] == '1' )
deposito ( guardar_conta , id_origem , valor );
if ( operacao[0] == '2' )
levantamento( guardar_conta , id_origem , valor );
}
}
}
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 = is_valid_number(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(guardar_conta);
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;
int movimentos_validos = 0;
int movimentos_invalidos =0;

typedef struct conta {
    char saldo[1000000];
    char limite_saldo[1000000];
    char id[11];
} 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 is_valid_n_chars(char * string, size_t size, char * chars) {
  int sindex = 0, cindex = 0;

  // ciclo de validação da string dada
  while(sindex < size && string[sindex] != '\0') {
    // pesquisa do caracter iterado na lista de caracteres válidos
    for (cindex = 0;
         chars[cindex] != '\0' && string[sindex] != chars[cindex];
         cindex++) /* void */;

    // verificação se o caracter foi encontrado
    if (chars[cindex] == '\0')
      return 0;

    // incremento da iteração
    sindex++;
  }

  // é válido se chegou ao fim da string com todos os caracteres validados
  // (verificação de string[sindex] == '\0' mas sindex < size)
  return sindex == size;
}

int is_valid_chars(char * string, char * chars) {
  return is_valid_n_chars(string, strlen(string), chars);
}

int is_valid_n_number(char * string, size_t size) {
  return is_valid_n_chars(string, size, "0123456789");
}

int is_valid_number(char * string) {
  return is_valid_n_number(string, strlen(string));
}

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);
}

int valida_opcao_mov ( char a[])
{
	if ( a[0] == '0' || a[0] == '1' || a[0] == '2')
		return 1;
	else 
		return 0;
}

void movimentos (Conta* guardar_conta)
{

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

    if (fp != NULL)
	{

		char temp[255+1];
        char * componentes;
        int contador = 0;
		char operacao[1];
		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, " ");
			
			while (componentes != NULL)
			{
			
				if (contador == 0 )
				{
					strcpy(operacao , componentes);
					valida_opcao_mov ( operacao );
				}
				else if(contador == 1)
				{
					strcpy( id_origem , componentes);
				}
				else if(contador == 2)
				{
					if ( operacao[0] == '0')
						strcpy(id_destino , componentes);
					if ( operacao[0] == '1' || operacao[0] == '2' )
						strcpy( valor , componentes );
				}
				else if( contador== 3)
					{
						if ( operacao[0] == '0')
							strcpy( valor , componentes );
						else
						{
							printf( "Movimento invalido\n");
							movimentos_invalidos++;
						}
					}
        
				componentes = strtok (NULL, " ");
				contador++;
			}
			if ( operacao[0] == '0' )
				transferencia( guardar_conta , id_origem , id_destino , valor);
			if ( operacao[0] == '1' )
				deposito ( guardar_conta , id_origem , valor );
			if ( operacao[0] == '2' )
				levantamento( guardar_conta , id_origem , valor );
		}
		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 =  is_valid_number(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(guardar_conta);
	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;
}