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 :

trier une list


Sujet :

C++

  1. #1
    Membre habitué

    Profil pro
    Inscrit en
    Avril 2004
    Messages
    421
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Avril 2004
    Messages : 421
    Points : 189
    Points
    189
    Par défaut trier une list
    bonjour,
    voila, j'ai un probleme de tri de list.

    j'ai une list declarer comme cela

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    std::list<Task*> m_task_manager;
    cad ave cdes pointer.

    si je fais list.tri. il me trie ca sur les pointeurs, or ce n'est pas ce que je veux, je dois trier ca sur plusieurs choses au cours du temps.

    j'ai vu sur
    http://www.cppreference.com/cpplist/sort.html

    qu'il ya moyen d'overrighter mais je ne comprend pas comment l'utiliser
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
     void sort( BinPred p );
    mais je ne comprend pas comment l'utiliser.

    pour exemple. voici une classe task

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    class Task{
    public :
    int a,
    int b,
    }
    a un certain moment, je dois la trier sur a, et a un autre, je dois la trier par rapport à b



    merci


    a++

  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 : 40
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Avril 2003
    Messages : 10 651
    Points : 15 920
    Points
    15 920

  3. #3
    Membre habitué

    Profil pro
    Inscrit en
    Avril 2004
    Messages
    421
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Avril 2004
    Messages : 421
    Points : 189
    Points
    189
    Par défaut
    mais en fait, ici, (et sur plusieurs autre site)
    http://www.msoe.edu/eecs/ce/courseinfo/stl/sort.htm

    il disent que sort de algo ne fonctionne pas sur les list.

    et le fait que cela soit des pointeurs d'objet (et non des objet eux meme) ne changerais il pas la donne??

    grand merci

    a++

  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 : 40
    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
    il disent que sort de algo ne fonctionne pas sur les list
    Effectivement il faut utiliser la fonction membre std::list::sort, comme tu semblais l'avoir vu dans ton premier post.

    et le fait que cela soit des pointeurs d'objet (et non des objet eux meme) ne changerais il pas la donne??
    C'est pour cela que tu dois utiliser un foncteur, comme indiqué dans la FAQ.

    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
    struct TriParA
    {
        bool operator ()(const Task* a, const Task* b) const
        {
            return a->a < b->a;
        }
    };
     
    struct TriParB
    {
        bool operator ()(const Task* a, const Task* b) const
        {
            return a->b < b->b;
        }
    };
     
    std::list<Task*> m_task_manager;
     
    // Trier selon le membre "a" :
    m_task_manager.sort(TriParA());
     
    // Trier selon le membre "b" :
    m_task_manager.sort(TriParB());

  5. #5
    Membre habitué

    Profil pro
    Inscrit en
    Avril 2004
    Messages
    421
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Avril 2004
    Messages : 421
    Points : 189
    Points
    189
    Par défaut
    merci , tout fonctionne impecablement.

    Par contre, je viens de relire mon premier post, --> go to bed().

    merci


    a+++

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 13/07/2006, 22h18
  2. Trier une liste chainée.
    Par gregb34 dans le forum Algorithmes et structures de données
    Réponses: 5
    Dernier message: 21/05/2006, 22h05
  3. Trier une liste de dossiers et de fichiers
    Par steveleg dans le forum Langage
    Réponses: 2
    Dernier message: 07/04/2006, 16h54
  4. [c#] Trier une liste de nombres liés.
    Par Joad dans le forum ASP.NET
    Réponses: 13
    Dernier message: 11/05/2005, 11h17
  5. [Debutant(e)]Trier une liste
    Par LeDébutantJava dans le forum Collection et Stream
    Réponses: 8
    Dernier message: 19/08/2004, 12h44

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