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 :

Taille D'un arbre AVL


Sujet :

C++

  1. #1
    Invité
    Invité(e)
    Par défaut Taille D'un arbre AVL
    je suis entrain de travaillé sur un petit projet en utilisant les arbres AVL
    SVP quelqu’un peux m'aider pour implémenter le fonction Taille sachant qu'il une autre fonction max que normalement sera utile
    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
     
    ///private:
        class Noeud{
          public:
            Noeud(const T&);
            Noeud *gauche;
            Noeud *droite;
            int equilibre;
            T element;
        };
    /********************/
     
     
    Template <class T>
    int  ArbreAVL<T>::hauteur() const{
        Noeud* n=racine;
       assert(n!=NULL)
     
        if(n->gauche!=NULL)
     
    	 if(n->equilibre > 0)
               n = n->gauche;
        if(n->droite!=NULL)
     
     
     
        hauteur(n->contenu);
       }
        return 0;
    }
    /***********************/
    template <class T>
    const T& ArbreAVL<T>::max(Noeud* n) const
    {
             assert(n!=NULL)
     
    	while (n->droite != NULL)
    		n = n->droite;
    	return  n->element;;
    }

  2. #2
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 369
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    Commence par définir ce que tu appelles la taille. Est-ce le nombre total d'éléments? Si oui, c'est assez facile:
    Code C++ : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    static int STaille(const Noeud *pNoeud)
    {
    	int taille = 0;
    	if(pNoeud==NULL)
    		return taille;
    	taille += STaille(pNoeud->gauche);
    	taille += 1;
    	taille += STaille(pNoeud->droite);
    	return taille;
    }
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  3. #3
    Invité
    Invité(e)
    Par défaut
    Citation Envoyé par Médinoc Voir le message
    Commence par définir ce que tu appelles la taille. Est-ce le nombre total d'éléments? Si oui, c'est assez facile:
    Code C++ : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    static int STaille(const Noeud *pNoeud)
    {
    	int taille = 0;
    	if(pNoeud==NULL)
    		return taille;
    	taille += STaille(pNoeud->gauche);
    	taille += 1;
    	taille += STaille(pNoeud->droite);
    	return taille;
    }
    merci
    deja j'ai l'impelemnter comme ca avant de voir votre reponse
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    template <class T>
    int  ArbreAVL<T>::hauteur() const{
        hauteur(racine);
     
    }
    template <class T>
    int  ArbreAVL<T>::hauteur(Noeud*& noeud) const
     
        if (noeud == NULL) return 0;
     
        int hauteur_gauche = hauteur(noeud->gauche);
        int hauteur_droit = hauteur(noeud->droite);
      return 1 + ((hauteur_gauche > hauteur_droit) ? hauteur_gauche : hauteur_droit);

  4. #4
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 369
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    Attention, je considère la hauteur différente du nombre total d'éléments. Je t'avais bien dit que le mot "taille" était ambigu.
    Ta fonction calcule la hauteur, la mienne le nombre total d'élements.

    Ensuite:
    • Pourquoi prendre le pointeur par référence? On ne le modifie pas...
    • Pourquoi le pointeur n'est-il pas const? On ne modifie pas le noeud pointé...
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

Discussions similaires

  1. Insertion arbre AVL c
    Par Antoine2220 dans le forum C
    Réponses: 2
    Dernier message: 02/12/2014, 23h07
  2. Arbre AVL probleme d'équilibrage
    Par selmagsi dans le forum Général Java
    Réponses: 2
    Dernier message: 09/01/2014, 17h38
  3. [GNU Pascal] Insertion dans un arbre AVL
    Par dorian100 dans le forum Autres IDE
    Réponses: 3
    Dernier message: 30/11/2012, 11h37
  4. arbres AVL -maximier/minimier
    Par Steph0 dans le forum C
    Réponses: 1
    Dernier message: 14/12/2009, 11h01
  5. Fonction taille et hauteur arbre binaire de façon itérative
    Par kalthoum dans le forum Autres langages
    Réponses: 1
    Dernier message: 04/12/2006, 19h55

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