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

SL & STL C++ Discussion :

Arbre binaire avec la STL ?


Sujet :

SL & STL C++

  1. #1
    Membre habitué Avatar de SteelBox
    Profil pro
    Inscrit en
    Novembre 2002
    Messages
    446
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Novembre 2002
    Messages : 446
    Points : 194
    Points
    194
    Par défaut Arbre binaire avec la STL ?
    Bonjour
    Savez vous comment on peut implémenter le plus efficacement possible un arbre binaire avec la STL ?
    Merci
    La vitesse de la lumière étant supérieure à celle du son, il apparaît normal que beaucoup de gens paraissent brillants jusqu'à ce qu'ils l'ouvrent.

  2. #2
    Rédacteur
    Avatar de Laurent Gomila
    Profil pro
    Développeur informatique
    Inscrit en
    Avril 2003
    Messages
    10 651
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Avril 2003
    Messages : 10 651
    Points : 15 920
    Points
    15 920
    Par défaut
    Tu as ici un exemple d'arbre STL-like.

    http://www.codeproject.com/Purgatory/Simple_STL_tree.asp

    Je ne me rappelle plus du contenu, mais vu le site ça ne devrait pas être moche.

  3. #3
    Membre habitué Avatar de SteelBox
    Profil pro
    Inscrit en
    Novembre 2002
    Messages
    446
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Novembre 2002
    Messages : 446
    Points : 194
    Points
    194
    Par défaut
    En fait, son exemple, c'est pour les arbres en général. Dans le cas d'un arbre binaire (un noeud a 2 fils), je ne crois pas qu'il soit très optimisé d'utiliser un vecteur...
    Sinon, c'est effectivement une bonne idée
    Merci
    La vitesse de la lumière étant supérieure à celle du son, il apparaît normal que beaucoup de gens paraissent brillants jusqu'à ce qu'ils l'ouvrent.

  4. #4
    Rédacteur
    Avatar de Laurent Gomila
    Profil pro
    Développeur informatique
    Inscrit en
    Avril 2003
    Messages
    10 651
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Avril 2003
    Messages : 10 651
    Points : 15 920
    Points
    15 920
    Par défaut
    Ben... oui, dans un arbre binaire tu auras juste un champ FilsDroit et un champ FilsGauche . En fait l'implémentation en elle-même n'est pas difficile, pour un arbre binaire "simple". L'important est de bien optimiser ses algos récursifs pour ne pas augmenter inutiulement la complexité de telle ou telle fonction. Après, vouloir le coder "avec la STL" n'est pas en soi une fin, l'interet pourrait par contre être de lui donner une interface STL-friendly, par exemple.

  5. #5
    Membre habitué Avatar de SteelBox
    Profil pro
    Inscrit en
    Novembre 2002
    Messages
    446
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Novembre 2002
    Messages : 446
    Points : 194
    Points
    194
    Par défaut
    une interface STL-friendly
    C'est quoi exactement ?
    Merci
    La vitesse de la lumière étant supérieure à celle du son, il apparaît normal que beaucoup de gens paraissent brillants jusqu'à ce qu'ils l'ouvrent.

  6. #6
    Expert éminent sénior
    Avatar de Luc Hermitte
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2003
    Messages
    5 275
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Août 2003
    Messages : 5 275
    Points : 10 985
    Points
    10 985
    Par défaut
    Une collection qui exporte des itérateurs ?

    Sinon, std::set n'est pas généralement implémenté comme un arbre binaire ?
    Blog|FAQ C++|FAQ fclc++|FAQ Comeau|FAQ C++lite|FAQ BS|Bons livres sur le C++
    Les MP ne sont pas une hotline. Je ne réponds à aucune question technique par le biais de ce média. Et de toutes façons, ma BAL sur dvpz est pleine...

  7. #7
    Rédacteur
    Avatar de Laurent Gomila
    Profil pro
    Développeur informatique
    Inscrit en
    Avril 2003
    Messages
    10 651
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Avril 2003
    Messages : 10 651
    Points : 15 920
    Points
    15 920
    Par défaut
    std::set est habituellement implanté sous forme d'arbre rouge et noir, ce qui est quand même un poil plus complexe que les arbres binaires classiques.

  8. #8
    Membre habitué
    Inscrit en
    Octobre 2004
    Messages
    616
    Détails du profil
    Informations forums :
    Inscription : Octobre 2004
    Messages : 616
    Points : 164
    Points
    164
    Par défaut
    hum, je ne connais pas encore les arbre rouge/noir, mais étant donné que ce sont des arbre je supose que le principe ne doit pas etre bien différent des AB et ABR, voir AVL .

    Le probleme selon moi, n'est pas d'arrivé a implémenter ca, ( réinventer la roue n'est pas toujours la meilleur solution...surtout si on ne sais pas a quoi sert cette roue ... ) mais d'arriver a comprendre coment ca s'utilise et a quoi sa sert !

    Une fois que tu sais ca, soit tu est assez bon en info pour pouvoir l'implementer de maniére efficace, soit tu le trouve deja tout fait .

    hum sinon j'avais trouvé sur google un bon pdf ( cours de fac ) sur les ab/abr, avec implementation en c++ ... tu devrai pouvoir le retrouver

  9. #9
    Membre habitué Avatar de SteelBox
    Profil pro
    Inscrit en
    Novembre 2002
    Messages
    446
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Novembre 2002
    Messages : 446
    Points : 194
    Points
    194
    Par défaut
    En fait, j'ai déjà implémenter un arbre binaire en C++ en cours. Mais je me demandais si la STL avait prévu quelque chose d'optimisée pour les arbres binaires, ce qui n'est apparement pas le cas...
    Merci
    La vitesse de la lumière étant supérieure à celle du son, il apparaît normal que beaucoup de gens paraissent brillants jusqu'à ce qu'ils l'ouvrent.

  10. #10
    Rédacteur
    Avatar de Laurent Gomila
    Profil pro
    Développeur informatique
    Inscrit en
    Avril 2003
    Messages
    10 651
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Avril 2003
    Messages : 10 651
    Points : 15 920
    Points
    15 920
    Par défaut
    La STL ne possède rien de spécifique aux arbres (à part en interne), mais rien ne t'empêche de tout de même utiliser ses fonctions / classes pour faire du code propre et sûr 8).

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Remplir un arbre binaire avec une table ordonnée.
    Par Invité dans le forum Algorithmes et structures de données
    Réponses: 1
    Dernier message: 26/11/2009, 16h20
  2. Réponses: 11
    Dernier message: 23/05/2008, 13h55
  3. Afficher un arbre binaire avec sa structure
    Par PhoneKilleR dans le forum C
    Réponses: 7
    Dernier message: 23/04/2008, 23h24
  4. Arbre binaire: Ajout précis avec récursion
    Par loic911 dans le forum Algorithmes et structures de données
    Réponses: 14
    Dernier message: 22/03/2008, 10h40
  5. probléme avec arbre binaire
    Par lanageuse56 dans le forum C
    Réponses: 13
    Dernier message: 17/05/2007, 16h50

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