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 :

Tri d'un tableau en 2D


Sujet :

C

  1. #1
    Membre du Club
    Inscrit en
    Novembre 2003
    Messages
    69
    Détails du profil
    Informations forums :
    Inscription : Novembre 2003
    Messages : 69
    Points : 59
    Points
    59
    Par défaut Tri d'un tableau en 2D
    Bonjour à tous, voici mon probleme. G un tableau contenant des messages et je voudrai le trier.... Voici un exemple pour clarifier mon problème.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    Mess[0]='Bonjour'
    Mess[1]='Au Revoir'
    Mess[2]='Comment'
    Mess[3]='Adieu'
     
    Et je voudrais le trier pour que ca devient :
     
    Resu[0]='Adieu'
    Resu[1]='Au revoir'
    Resu[2]='Bonjour'
    Resu[3]='Comment'
    Pour le moment, j'envisage de comparer chacun message avec les autres messages avec un strcmp et après noté chaque resusltat et après de construire un char Resu[4][150].. Mais si il y a 250message, ca fait beaucoup de comparaison ( 250 message * 249 message à comparé) .. Donc je cherche une autre solution un peu moins legere...

    Merci d'avance

  2. #2
    Membre confirmé
    Profil pro
    Inscrit en
    Juin 2005
    Messages
    731
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2005
    Messages : 731
    Points : 574
    Points
    574
    Par défaut
    Utilise un qsort et implémente une fonction de comparaison de chaînes de caractère, ça sera plus rapide.

  3. #3
    Membre du Club
    Inscrit en
    Novembre 2003
    Messages
    69
    Détails du profil
    Informations forums :
    Inscription : Novembre 2003
    Messages : 69
    Points : 59
    Points
    59
    Par défaut
    J'arrive pas trop à le faire , voici ce que j'ai mis :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    /***** Indispensable pour qsort *****/
    int compare(const void *arg1, const void *arg2 )
    {
       /* Compare all of both strings: */
       return strcmp((char *)arg2,(char *)arg1);
    }
     
    qsort((void *) table,longueur,sizeof(char *),compare);
    table = char table[5][5] <---Faute Corrigé
    longueur =int qui désigne le nbre de caractère par ligne (ici il est de 5)

    Le problème, c'est qui trie avec Seulement la première lettre, alors si il y a deux mots qui ont la même lettre , il ne sera pas bien triés. Par exemple il mettra : "Avoir","Bebes","Baver","Boire","Baton","Chien". Seule la première lettre est trié

  4. #4
    Expert éminent sénior

    Avatar de fearyourself
    Homme Profil pro
    Ingénieur Informaticien Senior
    Inscrit en
    Décembre 2005
    Messages
    5 121
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : Etats-Unis

    Informations professionnelles :
    Activité : Ingénieur Informaticien Senior
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2005
    Messages : 5 121
    Points : 11 877
    Points
    11 877
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    strcmp((char *)arg2,(char *)arg1);
    C'est faux parce que qsort va donner l'adresse de la donnée à trié donc cela sera un (char**)...

    table = char ** table[5][5]
    longueur =int qui désigne le nbre de caractère par ligne (ici il est de 5)

    Très bizarre ta façon de l'utiliser (tu n'as pas dû tout suivre), de plus, table devrait plutôt être du type char table[5][5] et non char **table[5][5]...

    Voici un code qui marche, il créé un tableau mess, et un tableau res... On affecte les adresses dans le tableau res comme ça on ne touche pas le tableau de départ...

    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
    32
    33
     
    #include <stdlib.h>
    #include <stdio.h>
     
     
    /***** Indispensable pour qsort *****/
    int compare(const void *arg1, const void *arg2 )
    {
       /* Compare all of both strings: */
       return strcmp(*((char **) arg1),*((char **)arg2));
    }
     
     
    int main()
    {
    char mess[4][20] = {"Bonjour","Au Revoir","Comment","Adieu"};
     
    char *res[4];
     
    int i;
     
    for(i=0;i<4;i++)
    	res[i] = mess[i];
     
    qsort((void *) res,4,sizeof(char *),compare); 
     
     
    for(i=0;i<4;i++)
    	printf("%s\n",res[i]);
     
     
    return 0;
    }

    Jc

  5. #5
    Membre du Club
    Inscrit en
    Novembre 2003
    Messages
    69
    Détails du profil
    Informations forums :
    Inscription : Novembre 2003
    Messages : 69
    Points : 59
    Points
    59
    Par défaut
    Oui!!!! ca marche , je te remercie , ton exemple m'a très bien aidé ...

    Au sujet de char ** table[5][5] , euh.. désolé de la(les) faute(s) d'orthographes, à force de travailler avec des pointeurs , on en voit partout .....

    Merci pour tout 8)

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

Discussions similaires

  1. Réponses: 9
    Dernier message: 13/02/2006, 08h39
  2. Réponses: 6
    Dernier message: 16/09/2005, 10h30
  3. tri d'un tableau à 2 dimensions
    Par dede92 dans le forum C
    Réponses: 4
    Dernier message: 19/02/2005, 18h29
  4. [langage] Probleme de tri d'un tableau de tableau
    Par Ludo167 dans le forum Langage
    Réponses: 1
    Dernier message: 25/08/2004, 10h32
  5. [] Tri d'un tableau par ordre alphabétique
    Par cafeine dans le forum VB 6 et antérieur
    Réponses: 3
    Dernier message: 17/09/2002, 08h43

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