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 :

Problème Arbre N-aire en C


Sujet :

C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre habitué
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2016
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 27
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2016
    Messages : 8
    Par défaut Problème Arbre N-aire en C
    Bonjour à tous,

    Je voudrais créer un arbre n-aire mais je me heurte à un problème. Mes algos ne comptent pas d'erreurs et de warnings. Cependant lors de l'affichage de l'arbre, il n'y a que la racine qui est affichée et pas les enfants. J'ai cherché dans mon ajout d'un arbre dans un autre ou dans ma fonction d'affichage mais je ne trouve pas de réponse à mon problème.

    Cordialement,
    Airox


    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
    68
    69
    70
     
    typedef struct Maillon{
     
        struct Maillon *next;
        void *info;
    }Maillon;
    typedef Maillon *Liste;
     
     
    typedef struct Node
    {
        char name[MAX];
        char tag[TAG_X][TAG_Y];
        int type;
        Maillon *childs;
     
    }Node;
    typedef Node *Tree;
     
    Tree createTree(char *title, int info)
    {
        Tree t;
     
        t=malloc(sizeof(Node));
     
        stringDup(&t,title);
     
        t->type=info;
        t->childs=NULL;
     
        return t;
    }
     
    void AddTree(Tree *a, Tree b)
    {
        Liste child = NULL;
     
        child = (*a)->childs;
     
        while(child != NULL)
        {
            child = child->next;
        }
     
        child=malloc(sizeof(Maillon));
        child->info = b;
        child->next=NULL;
    }
     
    void printTree(Tree t)
    {
        Liste child = NULL;
     
     
        if (t==NULL) return;
     
     
        printf("%s", t->name);
     
     
        child = t->childs;
     
        while(child!=NULL)
        {
            child->info=t;
            printTree(child->info);
            child=child->next;
        }
     
    }

  2. #2
    Membre confirmé

    Homme Profil pro
    automatisme
    Inscrit en
    Octobre 2012
    Messages
    59
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Mayenne (Pays de la Loire)

    Informations professionnelles :
    Activité : automatisme

    Informations forums :
    Inscription : Octobre 2012
    Messages : 59
    Par défaut
    Bonjour,
    dans ta fonction printTree(), tu fais une récursivité en appelant 'child->info', pour afficher tout un arbre, il faudrait plutôt appeler un frère ou un fils
    (je continue de regarder ce qui ne va pas)

  3. #3
    Membre Expert

    Homme Profil pro
    Responsable des études
    Inscrit en
    Mars 2009
    Messages
    553
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Responsable des études
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2009
    Messages : 553
    Par défaut
    Hello,

    Je suis surpris que tu ais deux structures pour ton arbre: Node et Maillon.
    Habituellement, un arbre est représenté à l'aide d'une seule structure, qui peut contenir (ou pas)
    une liste de noeuds enfants.

    En parcourant ton code, il y a plusieurs choses qui me semblent suspectes, mais en premier lieu ta fonction AddTree ne peut pas fonctionner en l'état: il manque le chainage entre le dernier Maillon de 'a', et celui que tu crées pour 'b'.

Discussions similaires

  1. [Graphique] affichage d'arbres n-aires
    Par jeepnc dans le forum Graphisme
    Réponses: 2
    Dernier message: 21/03/2006, 21h27
  2. Parcours en profondeur d'un arbre n-aire
    Par Premium dans le forum Langage
    Réponses: 11
    Dernier message: 20/02/2006, 08h01
  3. [debutant] parcours en profondeur arbre n-aire
    Par tx dans le forum Langage
    Réponses: 1
    Dernier message: 15/02/2006, 03h56
  4. construire un arbre n-aire
    Par emidelphi77 dans le forum Langage
    Réponses: 2
    Dernier message: 11/10/2005, 18h47
  5. arbre n-aire delete
    Par Fry dans le forum C++
    Réponses: 13
    Dernier message: 19/10/2004, 21h22

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