IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

C Discussion :

Initialisation d'un arbre avec liste


Sujet :

C

  1. #1
    Membre du Club
    Inscrit en
    Décembre 2005
    Messages
    172
    Détails du profil
    Informations forums :
    Inscription : Décembre 2005
    Messages : 172
    Points : 43
    Points
    43
    Par défaut Initialisation d'un arbre avec liste
    liste contient ke code morse de chaque lettre et je veux initialiser mon arbre avec cette liste.
    Le probleme c'est que j'ai un soucis pour une seule valeur de l'arbre qui le "A" qui est la premiere valeur de la liste.

    Code de l'arbre
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    #include "arbre.h"
     
    void creerArbre(Arbre* a)
    {
       *a = (Arbre)malloc(sizeof(Noeud));
       (*a)->lettre = ' ';
       (*a)->fgauche = NULL;
       (*a)->fdroit = NULL;
    }
    void InitArbre(Arbre a, Liste l)
    {
         int i = 0;
         l = l->suiv;
         while(l)
         {
             Arbre b = a;
             char* m = l->morse; 
             for(i = 0; *(m+i) != '\0'; i++)
             {    
                 Arbre e;
     
                 if (*(m+i)=='.') e = b->fgauche;
                 else e = b->fdroit;
     
                 //Arbre e = (*(m+i) == '.')? b->Gauche: b->Droit;    
                 if(e == NULL)
                 {
                     e = (Arbre)malloc(sizeof(Noeud));
                     e->fgauche = NULL;
                     e->fdroit = NULL;
                     if(*(m+i) == '.')
                         b->fgauche = e;
                     else
                         b->fdroit = e;
                 }
                 b = e;
             }
             b->lettre = l->c;
             l = l->suiv;
         }
    }
     
    void Afficher_arbre(Arbre a)
    {
         if (a!=NULL)
         {
              Afficher_arbre(a->fdroit);
              //Afficher_arbre(a->fgauche);
              printf("%c \n",a->lettre);
              Afficher_arbre(a->fgauche);
              //Afficher_arbre(a->fdroit);
         }
    }
     
    char ConvertirMorse(char* m, Arbre a)
    {
         int i = 0;
     
         for (i = 0; *(m+i) != '\0'; i++)
         {
             if(*(m+i) == '.')
                 a = a->fgauche;      
             else
                 a = a->fdroit;         
         }
         return a->lettre;    
    }

  2. #2
    Membre Expert

    Homme Profil pro
    Ingénieur R&D
    Inscrit en
    Juin 2003
    Messages
    4 506
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2003
    Messages : 4 506
    Points : 5 724
    Points
    5 724
    Par défaut
    *a = (Arbre)malloc(sizeof(Noeud));
    Tu aurais pas un probléme ici ? Par rapport au prototype de la fonction je verrais plus

    a = (Arbre)malloc(sizeof(Noeud));
    parce que malloc renvoi une adresse hors je vois pas comment tu pourrais stocker une adresse dans un arbre ( *a)
    " Dis ce que tu veux qui insulte mon honneur car mon silence sera la réponse au mesquin.
    Je ne manque pas de réponse mais : il ne convient pas aux lions de répondre aux chiens ! " [Ash-Shafi'i ]

  3. #3
    Membre du Club
    Inscrit en
    Décembre 2005
    Messages
    172
    Détails du profil
    Informations forums :
    Inscription : Décembre 2005
    Messages : 172
    Points : 43
    Points
    43
    Par défaut
    c'est bon j'ai troouvé le problème c'est que j'incremente la liste au depart alors qu'il ne faut pas Merci quand meme

  4. #4
    Membre Expert

    Homme Profil pro
    Ingénieur R&D
    Inscrit en
    Juin 2003
    Messages
    4 506
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2003
    Messages : 4 506
    Points : 5 724
    Points
    5 724
    Par défaut
    Si quelqu'un veut bien expliquer ce que je dis plus haut...
    " Dis ce que tu veux qui insulte mon honneur car mon silence sera la réponse au mesquin.
    Je ne manque pas de réponse mais : il ne convient pas aux lions de répondre aux chiens ! " [Ash-Shafi'i ]

  5. #5
    Membre du Club
    Inscrit en
    Décembre 2005
    Messages
    172
    Détails du profil
    Informations forums :
    Inscription : Décembre 2005
    Messages : 172
    Points : 43
    Points
    43
    Par défaut
    Par contre j'ai un autr rpoblème maintenant

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    void TraduireEnTexte(char *Fsource)
    {
        FILE *fTxt;
        char c;
        char ligne[100];
     
        int j;
        char *code;
     
     
     
        fTxt=fopen(Fsource,"r");
        if(fTxt==NULL) printf("Fichier existe pas\n");
        else
        {
              c=fscanf(fTxt,"%s$ \n",ligne);
              while(c!=EOF)
              {
                  /*j=strlen(ligne)+1;
                  code=(char*) malloc(sizeof(char)*j);
                  strcpy(code, ligne);
        
                  /***Ajoute sur liste ****/
                 // Ajouter(car,code,&l);
                  /***************************/
                  printf("%s",ligne);
               c=fscanf(fTxt,"%s$ \n",ligne);
              }
              fclose(fTxt);
         }
    }


    Avec ce code ci , j'aimerais extraire des chaines de caractere qui sont en faites des code morse le truc c'tes que j'aimrais reussir a extraire par exemple :
    -.-.
    du fichier qui contient ceci
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    -.-.$---$..-$-.-.$---$..-$
    -.-.$.-$ * ...-$.-$
    ---$-.-$ * ---$---$

  6. #6
    Expert éminent
    Avatar de PRomu@ld
    Homme Profil pro
    Ingénieur de Recherche
    Inscrit en
    Avril 2005
    Messages
    4 155
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Vienne (Poitou Charente)

    Informations professionnelles :
    Activité : Ingénieur de Recherche
    Secteur : Enseignement

    Informations forums :
    Inscription : Avril 2005
    Messages : 4 155
    Points : 6 486
    Points
    6 486
    Par défaut
    Citation Envoyé par hegros
    *a = (Arbre)malloc(sizeof(Noeud));
    Tu aurais pas un probléme ici ? Par rapport au prototype de la fonction je verrais plus

    a = (Arbre)malloc(sizeof(Noeud));
    parce que malloc renvoi une adresse hors je vois pas comment tu pourrais stocker une adresse dans un arbre ( *a)
    En fait ce n'est peut être pas une erreur, il faudrait connaître le type arbre en complet pour savoir comment ceci a été fait.

    Par contre, il faut arrêter avec les cast sur un malloc.

    Avec ce code ci , j'aimerais extraire des chaines de caractere qui sont en faites des code morse le truc c'tes que j'aimrais reussir a extraire par exemple :
    Et bien il faut le programmer ... . Tu récuères ta ligne et tu la traites caractère par caractère : tant que tu tombes pas sur une fin de mot ($), tu ajoute le symbole à ton code morse.

  7. #7
    Membre du Club
    Inscrit en
    Décembre 2005
    Messages
    172
    Détails du profil
    Informations forums :
    Inscription : Décembre 2005
    Messages : 172
    Points : 43
    Points
    43
    Par défaut
    je suis d'accord mais comment affecter ma valeur a la suite car tu me di de parcourir caractere par caractere et au moment ou je tombe sur "$" j'arrete.
    Je suis ok avec toi mais comment je fais pour concatener caractere par caractere je bloc un pe

  8. #8
    Expert éminent
    Avatar de PRomu@ld
    Homme Profil pro
    Ingénieur de Recherche
    Inscrit en
    Avril 2005
    Messages
    4 155
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Vienne (Poitou Charente)

    Informations professionnelles :
    Activité : Ingénieur de Recherche
    Secteur : Enseignement

    Informations forums :
    Inscription : Avril 2005
    Messages : 4 155
    Points : 6 486
    Points
    6 486
    Par défaut
    Le morse est un langage fini, dans le sens où tu connais le plus long code morse (désolé je ne connais que très peu le morse), par conséquent, tu prend un tableau qui est plus grand ou a la même taille que ton code le plus long et tu ranges les caractères un à un dans ton tableau.

  9. #9
    Rédacteur/Modérateur
    Avatar de Trap D
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    4 942
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2003
    Messages : 4 942
    Points : 6 498
    Points
    6 498
    Par défaut
    hegros >> apparemment, le type Arbre est déjà un pointeur donc comme il a pour prototype
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    void creerArbre(Arbre* a)
    il passe un double pointeur, ce n'est pas très lisible mais ça fonctionne.
    Pour ce qui est du décodage, si j'ai bien compris (les retours de fêtes ), pour ceci "-.-.$" par exemple, en supposant que $ est la fin du code et bien tu pars de la racine et tu suis les embranchements qui correspondent à chaque code '-' ou '.', si tu arrives à un noeud où il n'y a pas le fils qui correspond, tu prends le caractère correspondant et tu repars de la racine de l'arbre et qu'ne tu arrives au $ c'est pareil tu prends la lettre sur laquelle tu es (en fait je ne connais rien au morse mais ça paraît logique )
    "La haine seule fait des choix" - Koan Zen
    "Il ne faut pas être meilleur que les autres, il faut être meilleur que soi." Albert Jacquard
    "Ceux qui savent où ils ont posé leur parapluie ne sont pas alcooliques." - pgibonne.
    Faites du Prolog, ça vous changera les idées !
    Ma page Prolog
    Mes codes sources commentés

    Mon avatar : La Madeleine à la veilleuse de Georges de La Tour

  10. #10
    Membre du Club
    Inscrit en
    Décembre 2005
    Messages
    172
    Détails du profil
    Informations forums :
    Inscription : Décembre 2005
    Messages : 172
    Points : 43
    Points
    43
    Par défaut
    Citation Envoyé par Trap D
    hegros >> apparemment, le type Arbre est déjà un pointeur donc comme il a pour prototype
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    void creerArbre(Arbre* a)
    il passe un double pointeur, ce n'est pas très lisible mais ça fonctionne.
    Pour ce qui est du décodage, si j'ai bien compris (les retours de fêtes ), pour ceci "-.-.$" par exemple, en supposant que $ est la fin du code et bien tu pars de la racine et tu suis les embranchements qui correspondent à chaque code '-' ou '.', si tu arrives à un noeud où il n'y a pas le fils qui correspond, tu prends le caractère correspondant et tu repars de la racine de l'arbre et qu'ne tu arrives au $ c'est pareil tu prends la lettre sur laquelle tu es (en fait je ne connais rien au morse mais ça paraît logique )
    J'ai modifier mon code pour pouvoir ecrire dans le fichier mais ca ne marche pas

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
     
    void TraduireEnTexte(Arbre a,char *Fsource,char *Fdest)
    {
        FILE *fTxt;
        char c;
        char ligne[100];
        char morse[100];
     
        char lettre;
     
        int i;
    	int j;
     
    	FILE *FenTexte;
    	/******************************/
     
    	fTxt=fopen(Fsource,"r");
    	FenTexte=fopen(Fdest,"w");
     
        if(fTxt==NULL) printf("Fichier existe pas\n");
        else
        {
              c=fgets(ligne,100,fTxt);
              while(c!=NULL)
              {
                  i=0;
                  while (ligne[i]!='\0')
                  {       
                        j=0;
                        while (ligne[i]!='$')
                        {     
                              morse[j]=ligne[i];   
                              j++;
                              i++;
                        }
                       i++;
     
                       if (strcmp(morse," * ")==0)  fprintf(FenTexte," ");
                       else
                       {
                           lettre=ConvertirMorse(morse, a);
                           fprintf(FenTexte,"%c",lettre);
                       }                 
                  }
                  c=fgets(ligne,100,fTxt);
                  fprintf(FenTexte,"\n");
             }
         }
       fclose(fTxt);
       fclose(FenTexte);
    }
    Pourquoi ne fonctionne pas

  11. #11
    Expert éminent sénior

    Avatar de fearyourself
    Homme Profil pro
    Ingénieur Informaticien Senior
    Inscrit en
    Décembre 2005
    Messages
    5 121
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : Etats-Unis

    Informations professionnelles :
    Activité : Ingénieur Informaticien Senior
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2005
    Messages : 5 121
    Points : 11 877
    Points
    11 877
    Par défaut
    Pourquoi ne fonctionne pas
    Sans pouvoir tester, une première grosse erreur est de ne pas mettre de '\0' à la fin de ta chaîne de caractère morse...

    Jc

  12. #12
    Membre du Club
    Inscrit en
    Décembre 2005
    Messages
    172
    Détails du profil
    Informations forums :
    Inscription : Décembre 2005
    Messages : 172
    Points : 43
    Points
    43
    Par défaut
    ca ne fonctionne toujours pas j'ai incrementé j+1 et jai mis dans morse[j]='\0' et ne marche pas

    Ecoute je suis vraiment en galere depuis avant je recherche mon erreur et sans ssuccès je fais teste mais ca ne donne rien

  13. #13
    Expert éminent sénior

    Avatar de fearyourself
    Homme Profil pro
    Ingénieur Informaticien Senior
    Inscrit en
    Décembre 2005
    Messages
    5 121
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : Etats-Unis

    Informations professionnelles :
    Activité : Ingénieur Informaticien Senior
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2005
    Messages : 5 121
    Points : 11 877
    Points
    11 877
    Par défaut
    Citation Envoyé par Naruto_kun
    ca ne fonctionne toujours pas j'ai incrementé j+1 et jai mis dans morse[j]='\0' et ne marche pas
    En principe, ce n'est pas la peine d'incrémenter j... c'est fait directement lorsque tu remplis ton tableau...

    Simplement:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    while (ligne[i]!='$')
                        {     
                              morse[j]=ligne[i];   
                              j++;
                              i++;
                        }
                     i++; 
                     morse[j]='\0';
    Jc

  14. #14
    Rédacteur/Modérateur
    Avatar de Trap D
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    4 942
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2003
    Messages : 4 942
    Points : 6 498
    Points
    6 498
    Par défaut
    Salut
    J'ai un peu corrigé

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    void TraduireEnTexte(Arbre a,char *Fsource,char *Fdest)
    {
        FILE *fTxt;
        // char c; ne sert à rien
        char ligne[100];
        char morse[100];
     
        char lettre;
     
        int i;
       int j;
     
       FILE *FenTexte;
       /******************************/
     
       fTxt=fopen(Fsource,"r");
       FenTexte=fopen(Fdest,"w");
     
        if(fTxt==NULL) printf("Fichier existe pas\n");
        else
        {
              // ne sert à rien
              // c=fgets(ligne,100,fTxt);
              while(fgets(ligne,100,fTxt)!=NULL)
              {
                  i=0;
                  // peut-être ici ligne[i] != '\n' ??
                  while (ligne[i]!='\0')
                  {       
                        j=0;
                        while (ligne[i]!='$')
                        {     
                              morse[j]=ligne[i];   
                              j++;
                              i++;
                        }
                       morse[j] = 0;
                       i++;
     
                       if (strcmp(morse," * ")==0)  
                           fprintf(FenTexte," ");
                       else
                       {
                           lettre=ConvertirMorse(morse, a);
                           fprintf(FenTexte,"%c",lettre);
                       }                 
                  }
                  fprintf(FenTexte,"\n");
                  // c=fgets(ligne,100,fTxt);
             }
         }
       fclose(fTxt);
       fclose(FenTexte);
    }
    "La haine seule fait des choix" - Koan Zen
    "Il ne faut pas être meilleur que les autres, il faut être meilleur que soi." Albert Jacquard
    "Ceux qui savent où ils ont posé leur parapluie ne sont pas alcooliques." - pgibonne.
    Faites du Prolog, ça vous changera les idées !
    Ma page Prolog
    Mes codes sources commentés

    Mon avatar : La Madeleine à la veilleuse de Georges de La Tour

  15. #15
    Membre Expert

    Homme Profil pro
    Ingénieur R&D
    Inscrit en
    Juin 2003
    Messages
    4 506
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2003
    Messages : 4 506
    Points : 5 724
    Points
    5 724
    Par défaut
    Merci à Trap D et PRomu@ld d'avoir pris le temps de répondre. Il est vrai que si arbre est de type pointeur je comprends mieux. Vous avez des régles de nommage de variable pour aider à la lisibilité ?
    " Dis ce que tu veux qui insulte mon honneur car mon silence sera la réponse au mesquin.
    Je ne manque pas de réponse mais : il ne convient pas aux lions de répondre aux chiens ! " [Ash-Shafi'i ]

  16. #16
    Expert éminent sénior
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 67
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Points : 20 985
    Points
    20 985
    Par défaut
    Citation Envoyé par hegros
    Merci à Trap D et PRomu@ld d'avoir pris le temps de répondre. Il est vrai que si arbre est de type pointeur je comprends mieux. Vous avez des régles de nommage de variable pour aider à la lisibilité ?
    http://emmanuel-delahaye.developpez.com/codage.htm

    et ne jamais cacher les pointeurs...
    Pas de Wi-Fi à la maison : CPL

Discussions similaires

  1. Mal a la tete avec liste chainée d'objet
    Par Raton dans le forum C++
    Réponses: 23
    Dernier message: 03/08/2005, 22h13
  2. [LG] Arbre avec pascal
    Par mondanikoffi dans le forum Langage
    Réponses: 1
    Dernier message: 21/07/2005, 13h36
  3. Réponses: 5
    Dernier message: 17/05/2005, 09h34
  4. Aide à la saisie avec liste déroulante
    Par Oluha dans le forum Général JavaScript
    Réponses: 5
    Dernier message: 01/02/2005, 09h04
  5. Conditions avec liste de tuples
    Par Robert999 dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 12/07/2004, 11h01

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo