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 un tableau de classe selon l'un de ses champs (char *)


Sujet :

C++

Vue hybride

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

    Informations forums :
    Inscription : Décembre 2004
    Messages : 759
    Par défaut Trier un tableau de classe selon l'un de ses champs (char *)
    Bonjour,

    J'ai un tableau:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    CMyClass _mytab[MAX_NB];
     
    class CMyClass
    {
    ....
    char* nom
    ...
    //getter et setter associés
    }
    Avec quelle méthode puis-je trier le tableau selon le critère alphabétique du champ nom?

    merci.

  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
    std::sort ( RandomAccessIterator first, RandomAccessIterator last, Compare comp );

  3. #3
    Membre chevronné
    Avatar de Florian Goo
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    680
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Septembre 2008
    Messages : 680
    Par défaut
    Bonjour,

    Utilise plutôt les conteneurs de la STL (std::vector, std::list, …) à la place des vieux tableaux à la C.
    Tu verras, c'est tellement plus simple !
    Cours : Initiation à CMake
    Projet : Scalpel, bibliothèque d'analyse de code source C++ (développement en cours)
    Ce message a été tapé avec un clavier en disposition bépo.

  4. #4
    Expert éminent
    Avatar de koala01
    Homme Profil pro
    aucun
    Inscrit en
    Octobre 2004
    Messages
    11 644
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : Belgique

    Informations professionnelles :
    Activité : aucun

    Informations forums :
    Inscription : Octobre 2004
    Messages : 11 644
    Par défaut
    Saut,

    Déjà, si j'étais toi, je me dépêcherais de remplacer le tableau statique de ta classe par un joli std::vector<CMyClass>, et le champs nom par une encore plus jolie std::string nom.

    Tu verra comme cela pourra te faciliter la vie par la suite

    Ensuite, il sera sans doute temps de te poser la question de savoir si tu veux *réellement* disposer d'un acces aléatoire aux différents éléments de ton tableau, ou si tu souhaites qu'il reste trié "en toutes circonstances", ce qui rendra les recherches bien plus rapides, ou si tu envisage de toutes manière un acces "séquentiel" aux élément du "tableau".

    En effet, si tu peux accepter d'avoir un tableau momentanément non trié, mais de parcourrir l'ensemble de ses éléments de toutes manières l'un à la suite de l'autre et de manière séquentielle, une liste d'éléments semblerait plus adaptée.

    Si, de plus, tu souhaites que les différents éléments restent triés quoi qu'il arrive, il semblerait opportun de te diriger vers un set d'éléments, voire, vers une map utilisant une chaine comme clé et un élément de type cMyClass comme valeur.
    Cette solution aura sans doute l'inconvénient de rendre le nom redondant (présent un fois sous la forme de clé et une fois sous la forme du champs de la variable de type CMyClass), mais te permettra d'éviter d'avoir créer les différents foncteurs de comparaison requis pour les différents algorithmes de tri / de recherche, car tout existe déjà dans la classe string, ce qui en fait un candidat "pas trop mauvais" pour servir de clé dans une map

    D'autre part, si tu décide d'utiliser un set, il faut savoir que tu ne pourra accéder aux différents éléments que de manière constante, ce qui peut parfois poser problème (selon ce que tu veux faire des éléments contenus )

    Par contre, l'énorme avantage que tu pourra tirer de ces deux manière de stocker tes éléments sera que la recherche sera optimisée parce que les éléments seront toujours triés...

    N'oublie pas que, quoi qu'il arrive, une fois que le champs nom de ta structure aura été utilisé comme clé, il faudra veiller à ce que sa valeur ne soit plus jamais modifiée, sous peine de placer tes données dans un état incohérent.

    Sinon, dans l'ensemble, que tu décides d'utiliser un vector, une list, ou un set, le plus facile (et généralement requis) pour effectuer un tri / une recherche, c'est de disposer d'un foncteur nommé less qui renvoie vrai si l'élément de gauche dans la comparaison elem1 < elem2 est plus grand que l'élément de droite.

    Une fois ce foncteur créé, il te sera très simple, selon le choix du conteneur que tu auras effectué, d'utiliser soit un algorithme de tri comme std::sort, soit un conteneur trié, de type set
    A méditer: La solution la plus simple est toujours la moins compliquée
    Ce qui se conçoit bien s'énonce clairement, et les mots pour le dire vous viennent aisément. Nicolas Boileau
    Compiler Gcc sous windows avec MinGW
    Coder efficacement en C++ : dans les bacs le 17 février 2014
    mon tout nouveau blog

  5. #5
    Membre éclairé
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    759
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 759
    Par défaut
    J'aurais du préciser mais il n'est pas question de remanier l'ensemble du code de ce programme.
    Donc voilà ce qui est utilisé et c'est juste une petite modification à apporter.

    Je suis autant désolé que vous mais il faut absolument que je parte de ce tableau (il est rempli à plein d'endroits dans le code et à la fin, j'écris le contenu dans un fichier; et c'est simplement là que j'aurais besoin de le trier avant d'écrire).

    Si je fais
    vector<CMyClass> myvector (_mytab, myints+nb_elements);
    vector<CMyClass>::iterator it;
    est-ce que je peux m'en sortir après avec mes comparaisons de char* pour une éventuelle fonction sort?

  6. #6
    Membre chevronné
    Avatar de Florian Goo
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    680
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Septembre 2008
    Messages : 680
    Par défaut
    Dans ce cas, utilise std::sort comme te l'a indiqué 3DArchi.
    Les itérateurs de début et de fin correspondent à table et table + MAX_NB.

    EDIT: Un lien vers un article sur les algorithme de la STL (comprenant std::sort) : http://r0d.developpez.com/articles/algos-stl/
    Cours : Initiation à CMake
    Projet : Scalpel, bibliothèque d'analyse de code source C++ (développement en cours)
    Ce message a été tapé avec un clavier en disposition bépo.

  7. #7
    Membre éclairé
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    759
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 759
    Par défaut
    OK, c'est facile avec des int mais pour trier des CMyClass, c'est une autre paire de manches.

  8. #8
    Membre chevronné
    Avatar de Florian Goo
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    680
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Septembre 2008
    Messages : 680
    Par défaut
    Oui… moi-même, quand j'arrive à écrire un appel à un algorithme de la STL qui fonctionne, je me sens dans la peau d'un être supérieurement intelligent (un de ces quatre, va falloir que je me le paie, cet Effective STL).

    Vas-y étape par étape. Tout d'abord, écris la fonction (libre) de comparaison qui va bien. Elle doit renvoyer bool et prendre deux références constantes de CMyClass.
    Cours : Initiation à CMake
    Projet : Scalpel, bibliothèque d'analyse de code source C++ (développement en cours)
    Ce message a été tapé avec un clavier en disposition bépo.

  9. #9
    yan
    yan est déconnecté
    Rédacteur
    Avatar de yan
    Homme Profil pro
    Ingénieur expert
    Inscrit en
    Mars 2004
    Messages
    10 035
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur expert
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mars 2004
    Messages : 10 035
    Par défaut
    Un truc comme
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    struct test
    {
    bool operator(const CMyClass* t1, const CMyClass* t2)
     { 
          return strcmp(t1->nom,t2->nom) <0;
     }
     
    }
    ...
    std::sort( _mytab, _mytab+MAX_NB, test())
    Mais faut mieux que tu ajout l'operator= dans CMyClass. SInon t'aura des truc bizzare

  10. #10
    Membre éclairé
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    759
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 759
    Par défaut
    Bonjour,

    Merci à tous; je vais regarder ça.

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

Discussions similaires

  1. Algo - Trier un tableau d'objets selon 2 critères
    Par identifiant_bidon dans le forum Collection et Stream
    Réponses: 3
    Dernier message: 08/07/2013, 11h51
  2. Trier une liste de classe selon un attribut
    Par pedro570 dans le forum Général Python
    Réponses: 4
    Dernier message: 06/05/2013, 18h04
  3. comment trier les instances d'une classe selon un attribut choisi
    Par rddev dans le forum Collection et Stream
    Réponses: 4
    Dernier message: 29/05/2007, 00h01
  4. Réponses: 5
    Dernier message: 02/04/2007, 17h49
  5. Trier un tableau de plusieurs type de classes.
    Par storm_2000 dans le forum Collection et Stream
    Réponses: 8
    Dernier message: 14/01/2007, 15h50

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