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

Visual C++ Discussion :

Trier un tableau de structures suivant un champ chaine de caracteres


Sujet :

Visual C++

  1. #1
    Membre habitué
    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
    Points : 159
    Points
    159
    Par défaut Trier un tableau de structures suivant un champ chaine de caracteres
    Bonjour,

    Une fonction très bien pour trier des tableaux de structures selon la valeur d'un champ nombre existe, c'est qsort.

    Mais elle ne semble pas transposable à des chaines :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    qsort((Cmytype*)_tab, _nbtab, sizeof(Cmytype), compare_chaines);
     
    int compare_chaines(const void *valeur1, const void *valeur2)
    {
    	if ((*(Cmytype*)valeur1).getNom() != (*(Cmytype*)valeur2).getNom())
    		return 1;
    	else 
    		return 0;
    }
    Avez-vous une solution autre que de faire l'exporation du tableau _tab manuellement en remplissant un autre tableau provisoire et en réinjectant tout dans _tab?

    Merci.

  2. #2
    Membre émérite
    Avatar de la drogue c'est mal
    Profil pro
    Inscrit en
    Novembre 2002
    Messages
    2 253
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2002
    Messages : 2 253
    Points : 2 747
    Points
    2 747
    Par défaut
    si getNom() renvoit un CString, tu peux utiliser la methode Compare
    il y a du linge sur la corde à linge

  3. #3
    Membre habitué
    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
    Points : 159
    Points
    159
    Par défaut
    Citation Envoyé par la drogue c'est mal
    si getNom() renvoit un CString, tu peux utiliser la methode Compare
    Non, mais je n'ai pas de problème avec la méthode getNom de ma classe de chaines de caractères qui sait reconnaitre deux chaines identiques.
    Le problème, c'est que renvoyer 1 en cas de différence et 0 en cas d'égalité ne suffit pas à ce que la fonction qsort fasse correctement son travail.

    Pour information, lorsqu'il s'agit de comparer des nombres dans la fonction de comparaison, on renvoyait 1 si a>b, 0 si a=b et -1 si a<b.
    Et là le tri de qsort fonctionne puisqu'elle permute ou pas les éléments en parcourant le tableau (tri à bulles je crois).
    Mais là, ça ne s'applique pas à des chaines si tu vois ce que je veux dire.

  4. #4
    Rédacteur
    Avatar de farscape
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Novembre 2003
    Messages
    9 055
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

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

    Informations forums :
    Inscription : Novembre 2003
    Messages : 9 055
    Points : 17 323
    Points
    17 323
    Par défaut
    salut,
    ton test est faux tout simplement...
    relis la doc de qsort:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    int compare( const void *arg1, const void *arg2 )
     {
     /* Compare all of both strings: */    
    return _stricmp( * ( char** ) arg1, * ( char** ) arg2 ); 
    }
    la remarque la drogue c'est mal est tout à fait pertinente ...

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

Discussions similaires

  1. trier un tableau de structures
    Par abdelghani666 dans le forum Débuter
    Réponses: 8
    Dernier message: 03/02/2012, 13h46
  2. Réponses: 4
    Dernier message: 19/02/2008, 13h46
  3. Trier/chercher dans un tableau de structure
    Par cata2 dans le forum MATLAB
    Réponses: 1
    Dernier message: 01/11/2007, 11h07
  4. Réponses: 5
    Dernier message: 13/06/2006, 11h08
  5. Trier un tableau de structures
    Par Yux dans le forum C
    Réponses: 7
    Dernier message: 05/11/2005, 17h28

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