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 :

parcours en largeur d'un arbre avec file


Sujet :

C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Décembre 2009
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2009
    Messages : 12
    Par défaut parcours en largeur d'un arbre avec file
    Bonjour,
    J'ai un Tp à rendre sur les arbres, le probléme c'est que lorsque je traduit l'algorithme de parcours que le proff nous a écrit au tableau en langage c++, il ne parcours pas tous l'arbre.J'utilise les files pour le parcours.(mon programme ne fait que les fils de la racine et s'arrête)

    pourriez vous s'il vous plait m'aider.
    MERCI D'AVANCE

    LA STRUCTURE
    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
    typedef struct noeudArbre {
    	int valeur;
    	struct noeudArbre* gauche;
    	struct noeudArbre* droite;
    } noeudArbre;
    typedef noeudArbre* arbre;
     
     typedef struct noeud{
         int info;
        struct noeud *suiv;
        struct noeud *prec;
     }noeud;
     typedef noeud*liste;
     
    typedef struct file{
       noeud *tete;
        noeud *queue;
        int taille;
    }file;
    LA FONCTION LARGEUR
    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
    void plargeur(arbre a)
     {
        if(a==NULL)
     {
            return ;
        }
        file f=initFile();
        enfiler(&f,(a->valeur));
     
        while((taille(f)!=0)) 
    {
            noeudArbre* e;
            defiler(&f,&(e->valeur));
            if(e->gauche!=NULL)
     {
                enfiler(&f,(e->gauche)->valeur);
            }
            if(e->droite!=NULL)
     {
                enfiler(&f,(e->droite)->valeur);
            }
        }
    }

  2. #2
    Rédacteur
    Avatar de 3DArchi
    Profil pro
    Inscrit en
    Juin 2008
    Messages
    7 634
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2008
    Messages : 7 634
    Par défaut
    Bonjour,
    Tu dois le faire en C ou en C++ ? Car le code que tu nous montre ressemble uniquement à du C.

    Il te manque simplement de quoi aller au suivant. Ensuite cela dépend si tu peux utiliser une approche récursive ou pas.

  3. #3
    Membre habitué
    Profil pro
    Inscrit en
    Décembre 2009
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2009
    Messages : 12
    Par défaut
    merci de votre réponse

    Mon programme se fait effectivement en C.
    Et mon problème s'est que le programme ne passe pas au suivant, et oui on peut le faire par récursivité.

    MERCI D'AVANCE

Discussions similaires

  1. Parcours en largeur d'un arbre binding problem
    Par souki22 dans le forum C++
    Réponses: 3
    Dernier message: 19/01/2015, 10h16
  2. Parcours d'un arbre avec java
    Par Allouli2010 dans le forum Débuter avec Java
    Réponses: 6
    Dernier message: 01/02/2012, 19h56
  3. Parcours arbre avec les iterateurs
    Par Premium dans le forum Collection et Stream
    Réponses: 16
    Dernier message: 24/03/2006, 15h03

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