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 :

Arbre Binaire De Recherche


Sujet :

C

  1. #1
    Candidat au Club
    Inscrit en
    Mai 2007
    Messages
    5
    Détails du profil
    Informations forums :
    Inscription : Mai 2007
    Messages : 5
    Points : 2
    Points
    2
    Par défaut Arbre Binaire De Recherche
    salut
    j'ai cherché un tutoriel expliquant les arbre binaires de recherche et ses application elementaires (inserer,supprimer, rechercher,atille,hauteur........) , mais j'ai pas trouvé grand chose


    je cherche surtou sur ce topic a comprendre ce passage d'insertion , avec un shema simple et detaillé si possible

    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
    void inser (pnoeud *p ,int data)
    {pnoeud q;
     q=feuille (data) ;
     if
     ((*p)-> data <= data ) 
     (*p)->fD=q ;
     else
     (*p)->fG=q ;}
     
     
     
     void inserer ( int data)
     { 
          pnoeud pere=place(data,racine)
    inser (&pere,data);
    }
    meci beaucoup

  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
    Sans connaitre les fonctions feuille, place, etc., pas tellement moyen...

    De plus, ce code semble utiliser un peu trop les variables globales (notamment la racine de l'arbre).
    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
    Membre averti Avatar de vdumont
    Profil pro
    Étudiant
    Inscrit en
    Février 2006
    Messages
    510
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : Canada

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2006
    Messages : 510
    Points : 369
    Points
    369

  4. #4
    Membre du Club
    Inscrit en
    Avril 2007
    Messages
    143
    Détails du profil
    Informations personnelles :
    Âge : 37

    Informations forums :
    Inscription : Avril 2007
    Messages : 143
    Points : 57
    Points
    57
    Par défaut
    J'espere que ca poura te servir.

    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
     
    typedef struct noeud
    {
     int val;
     struct noeud * fils_gauche;
     struct noeud * fils_droit;
    } Noeud, * Arbre;
     
    void insertionABR(Arbre a, int valeur)
    {
     if (!a) return; // noeud NULL condition d'arret de la recurrence
     
     if (valeur<=a->val) /* proprieté des ABR, toutes val < racine se trouvent dans le sous arbre gauche */
       {
        if (a->fils_gauche==NULL) 
         {
               Arbre new_noeud=creerNoeud(valeur);
               a->fils_gauche=new_noeud;
            }
            else
                 insertionABR(a->fils_gauche,valeur);
         }     
         else { /* proprieté des ABR, toutes val > racine se trouvent dans le sous arbre droit */
            if (a->fils_droit==NULL) 
              {
               Arbre new_noeud=creerNoeud(valeur);
               a->fils_droit=new_noeud;
              }
             else
                 insertionABR(a->fils_droit,valeur);
         }
    }

  5. #5
    Membre régulier
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    131
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 131
    Points : 114
    Points
    114
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
      1 
      2 void inser (pnoeud *p ,int data) {
      3     pnoeud q;
      4     q=feuille (data);
      5     if ((*p)-> data <= data)
      6         (*p)->fD=q ;
      7     else 
      8         (*p)->fG=q;
      9 }
    tu pourrais utiliser la recursivite pour ton insertion de noeud.
    De plus cela me derange que tu utilise
    (*p)-> data
    .
    Soit Soit

Discussions similaires

  1. Conformité arbre binaire de recherche
    Par Gasimoto dans le forum Lisp
    Réponses: 19
    Dernier message: 30/12/2007, 23h20
  2. Suppression dans un arbre binaire de recherche
    Par zeine77 dans le forum Langage
    Réponses: 1
    Dernier message: 11/05/2007, 20h40
  3. Réponses: 3
    Dernier message: 31/12/2005, 12h30
  4. Réponses: 11
    Dernier message: 07/04/2004, 13h06
  5. [Arbre binaire de Recherche]
    Par Giovanny Temgoua dans le forum Algorithmes et structures de données
    Réponses: 11
    Dernier message: 06/02/2004, 11h45

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