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

Bibliothèque standard C Discussion :

utilisation de qsort et bsearch


Sujet :

Bibliothèque standard C

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2003
    Messages
    116
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2003
    Messages : 116
    Points : 40
    Points
    40
    Par défaut utilisation de qsort et bsearch
    Bonjour,
    j'ai un problhme avec l'utilisation de qsort et bsearch pour trier et faire une recherche sur un tableau de long en C

    Voici mon code :
    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
     
    void query_and(long first_query[MAX_RESULT], long second_query[MAX_RESULT], long result_query[MAX_RESULT])
    {
            int i = 0;
            int ind = 0;
            int size1 = sizeof(first_query);
            int size21 = sizeof(second_query);
     
            //tri les deux tableaux
            qsort(first_query, sizeof(first_query), sizeof(long), (long (*) (const void*, const void*)) compare_long);
            qsort(second_query, sizeof(second_query), sizeof(long), (long (*) (const void*, const void*)) compare_long);
     
            //recherche les valeurs identiques dans les deux tableaux
            while(i<sizeof(first_query))
            {
                    long* long_ptr = bsearch(second_query, first_query[i], sizeof(second_query), sizeof(long), 
                                             (long (*) (const void *, const void *)) compare_long);
                    if(*long_ptr)
                    {
                            result_query[ind] = first_query[i];
                            ind++;
                    }
                    i++;
            }
     
    }
     
    int compare_long(long* a, long* b)
    {
            return(*a - *b);
    }
    Problhre rencontri :
    - qsort :
    le tableau est bien trier sauf sont derriere element.
    exemple:
    AVANT
    {55, 2, 45, 1, 54}
    APRES
    {1, 2, 45, 55, 54}

    - bsearch
    Quand il passe dans la fonction compare-long, *b est toujours inditermini et donc il plante.

    Quelq'un aurait-il un idie?

    Merci

  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

    Le cast explicite de pointeurs de fonction est une très mauvaise chose, tu sais...

    Et tes sizeof() sont très mal employés: qsort() attend le nombre d'éléments, et tu lui passes la taille du tableau en octets...
    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
    Expert éminent sénior
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 67
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Points : 20 985
    Points
    20 985
    Par défaut
    Citation Envoyé par hitchie Voir le message
    j'ai un problhme avec l'utilisation de qsort et bsearch pour trier et faire une recherche sur un tableau de long en C
    Il faut mieux lire la doc des fonctions....

    http://emmanuel-delahaye.developpez.com/qsort.htm

    Ne pas hésiter à expérimenter les choses une par une...
    Pas de Wi-Fi à la maison : CPL

Discussions similaires

  1. Trier un tableau en utilisant qsort
    Par IngenieurElec dans le forum Débuter
    Réponses: 5
    Dernier message: 23/11/2012, 15h03
  2. Utilisation de qsort() en c
    Par fictifboy dans le forum Débuter
    Réponses: 6
    Dernier message: 25/11/2009, 21h36
  3. utiliser qsort avec void**
    Par dj.motte dans le forum C
    Réponses: 24
    Dernier message: 04/02/2007, 09h05
  4. Utilisation de la fonction qsort
    Par Jsmeline dans le forum C
    Réponses: 8
    Dernier message: 28/01/2005, 12h40
  5. Réponses: 2
    Dernier message: 20/03/2002, 23h01

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