Jump to content
Sign in to follow this  
Maradona101

Inserção em ficheiro usando Arvore Binária

Recommended Posts

Maradona101

 void Inserir (arvore_ptr *pai, int t, char n[], int p, int cp) {    
        if ((*pai)) {     
            if (t < (*pai) -> Telefone)    
               Inserir(&((*pai) -> esq), t, n, p, cp);     
            else    
               Inserir(&((*pai) -> dir), t, n, p, cp);    
        }    
        else {     
            (*pai) = (arvore_ptr) malloc (sizeof (struct Telefones));     
                if (*pai) {     
                      (*pai) -> Telefone = t;     
                       strcpy((*pai) -> nome, n);    
                      (*pai) -> NPorta = p;    
                      (*pai) -> codPostal = p;
                      (*pai) -> esq = NULL;     
                      (*pai) -> dir = NULL;    
                }    
            }
            FILE *fp;    
       fp = fopen ("C:\\Binario.dat", "ab"); //wb para escrita //rb para leitura    
       if (fp == NULL) {    
          printf ("Erro ao abrir o arquivo.\n");    
          exit(1);    
       }    
       else {    
       //if (fp != NULL) {}    
       printf ("Guardado");     
       fwrite(&raiz, sizeof(raiz), sizeof(raiz), fp);    
       fclose (fp);  
       
       }      
    }    
      

Boas. AO executar estre procedimento pela primeira vez, insere normalmente, ao executar pela segunda vez, insere duas vezes pois a mensgaem Guardado é mandada para o ecrã duas vezes. Ao executar pela 3ª vez consecutiva guarda 3 vezes e assim sucessivamente, não consigo indentifcar qualo problema.

Cumprimentos.

Share this post


Link to post
Share on other sites
KTachyon

Cheira-me que o que é executado duas vezes é o método em si. Não existe nenhum loop na função, logo só irá imprimir isso duas vezes se estiveres a chamar a função duas vezes. Seja o que for que está mal, está fora desta função.


“There are two ways of constructing a software design: One way is to make it so simple that there are obviously no deficiencies, and the other way is to make it so complicated that there are no obvious deficiencies. The first method is far more difficult.”

-- Tony Hoare

Share this post


Link to post
Share on other sites
Maradona101

case 1:{    
                       printf("\nDigite o telefone: ");     
                       gets(temp);    
                                   entrada = atoi(temp);    
            
                       printf("digite o nome: ");    
                       gets(nome1);    
            
                       printf("digite o n Porta: ");    
                       gets(temp);    
                       np = atoi(temp); //string para float  
                       
                       printf("digite o cod Postal: ");    
                       gets(temp);    
                       cp = atoi(temp); //string para float  
                         
                       Inserir(&raiz,entrada, nome1, np, cp);    
                       break;    
                       }    
                       

Só chamo a função aqui.

Share this post


Link to post
Share on other sites
KTachyon

Mete um \n no final do printf() só para garantir que ele faz o flush imediatamente.

PS: As boas práticas dizem que nomes de funções devem ser iniciados com letra pequena.


“There are two ways of constructing a software design: One way is to make it so simple that there are obviously no deficiencies, and the other way is to make it so complicated that there are no obvious deficiencies. The first method is far more difficult.”

-- Tony Hoare

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
Sign in to follow this  

×
×
  • Create New...

Important Information

By using this site you accept our Terms of Use and Privacy Policy. We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.