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'index de tableau par rapport au contenu


Sujet :

C

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2005
    Messages : 12
    Points : 8
    Points
    8
    Par défaut tri d'index de tableau par rapport au contenu
    Bonjour,

    je suis totalement debutant en C et j'essaye de faire un truc en essayant
    au passage de comprendre.

    j'ai une variable tab[5] qui contient :
    tab[0]=8;
    tab[1]=3;
    tab[2]=25;
    tab[3]=1;
    tab[4]=40;

    je veux savoir au final que 4 > 2 > 0 > 1 > 3.

    j'ai tout essayé avec qsort, mais rien à faire. j'arrive à trier le contenu des variables du tableau, mais pas à trier l'index en fonction du contenu.

    Quelqu'un peut il me donner une idée avec un code le plus simple possible ?

    Merci beaucoup.


    pour vous donner une idée de mon niveau nullissime en c (en esperant que quelqu'un sera suffisement attentionné pour donner un code qui soit de mon niveau), voici ce que j'ai fait pour trier le contenu du tableau :

    int tab[5];
    memset( &tab, 0, sizeof tab );

    tab[0]=8;
    tab[1]=3;
    tab[2]=25;
    tab[3]=1;
    tab[4]=40;

    qsort(&tab[0], TAILLE, sizeof(int), Tri);


    et la fonction de tri :

    int Tri(const void* _a, const void* _b) {
    if (*(int*)_a<*(int*)_b) return 1;
    if (*(int*)_a==*(int*)_b) return 0;
    if (*(int*)_a>*(int*)_b) return -1 ;
    }

  2. #2
    Membre habitué Avatar de _kal_
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Janvier 2006
    Messages
    178
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Janvier 2006
    Messages : 178
    Points : 156
    Points
    156
    Par défaut
    Je peux savoir pourquoi tu fait des allocation de mémoires ?

    Quand j'utilise un tableau, je fait tout simplement par expl :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    int t[] = { 1, 2 ,3 ,4 ,5};
    ou encore

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    int t[5];
    int i;
    for( i = 0 ; i < 5 ; i++)
        t[i] = i;

  3. #3
    Futur Membre du Club
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    12
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2005
    Messages : 12
    Points : 8
    Points
    8
    Par défaut
    simplement parce que dans le programme reel, je remplis le tableau à partir d'un fichier et qu'il a une taille de plusieurs milliers d'elements.

    Là j'ai simplifié pour l'exemple.

  4. #4
    Rédacteur/Modérateur
    Avatar de Trap D
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    4 942
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2003
    Messages : 4 942
    Points : 6 498
    Points
    6 498
    Par défaut
    Pour la fonction tri, tu peux simplement faire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    nt Tri(const void* _a, const void* _b) {
    /*
    if (*(int*)_a<*(int*)_b) return 1;
    if (*(int*)_a==*(int*)_b) return 0;
    if (*(int*)_a>*(int*)_b) return -1 ;
    */
      return *(int *) _b - * (int *) _a; 
    }
    A noter qu'il n'est pas très judicieux de faire débuter les noms de variables par des _ qui sont réservés en général à l'implémentation.
    "La haine seule fait des choix" - Koan Zen
    "Il ne faut pas être meilleur que les autres, il faut être meilleur que soi." Albert Jacquard
    "Ceux qui savent où ils ont posé leur parapluie ne sont pas alcooliques." - pgibonne.
    Faites du Prolog, ça vous changera les idées !
    Ma page Prolog
    Mes codes sources commentés

    Mon avatar : La Madeleine à la veilleuse de Georges de La Tour

  5. #5
    Expert éminent sénior
    Avatar de diogene
    Homme Profil pro
    Enseignant Chercheur
    Inscrit en
    Juin 2005
    Messages
    5 761
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Enseignant Chercheur
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 761
    Points : 13 926
    Points
    13 926
    Par défaut
    Si je comprend ton problème, tu veux obtenir la position de la valeur des éléments du tableau dans l'ordre décroissant, et non trier le tableau Tab lui-même. Il faut donc stocker ces positions dans un tableau . C'est ce tableau qu'on va trier sachant que la fonction de tri doit comparer non pas les éléments de ce tableau mais les éléments de Tab qui sont repérés par ce tableau. Il faut donc un tableau supplémentaire pour stocker le résultat et je ne vois pas comment s'en passer.
    Par exemple :
    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
    int tab[5] ;
    int *ptab[5];
    int i;
    /* Chargement du tableau tab . Dans ton exemple*/
    tab[0]=8;
    tab[1]=3;
    tab[2]=25;
    tab[3]=1;
    tab[4]=40;
    /* Initialisation de ptab par les adresses des éléments de tab */
    for(i=0;i<5;i++) ptab[i] = tab+i;
    /* tri de ptab, la fonction de tri doit être adaptée voir plus loin*/
    qsort(ptab, 5, sizeof(int*), Tri);
    /* ptab[0] contient l'adresse du plus grand élément,
       ptab[1] contient l'adresse de l'élément suivant , etc 
       Si on préfère obtenir l'indice correspondant à l'élément de rang n calculer
       i = ptab[n]-tab;*/
    ....
    La fonction Tri correspondante (d'après la remarque de Trap D)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    int Tri(const void* _a, const void* _b)
     { 
      return **(int **) _b - **(int **) _a; 
    }
    Publication : Concepts en C

    Mon avatar : Glenn Gould

    --------------------------------------------------------------------------
    Une réponse vous a été utile ? Remerciez son auteur en cliquant le pouce vert !

  6. #6
    Membre habitué
    Profil pro
    Inscrit en
    Novembre 2005
    Messages
    147
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2005
    Messages : 147
    Points : 155
    Points
    155
    Par défaut
    Tu ne pourras pas trier le tableau ET trier les index ...
    vu que les index vont changer quand tu vas trier le tableau ...

    Je ne garantis pas que ce soit la solution la plus propre, mais si tu peux,
    tu fais un second tableau, qui contiendra tes index
    Ce nouveau tableau contiendra les index, dans l'ordre des valeurs du premier tableau ...
    tu pourras y acceder comme suit :

    tableau_des_valeurs[tableau_des_index[ieme_valeur]]

  7. #7
    Expert confirmé
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Décembre 2003
    Messages
    3 549
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Décembre 2003
    Messages : 3 549
    Points : 4 625
    Points
    4 625
    Par défaut
    Le problème a apparemment été résolu sur fr.comp.lang.c
    Boost ftw

  8. #8
    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 Re: tri d'index de tableau par rapport au contenu
    Citation Envoyé par parisien
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    qsort(&tab[0], TAILLE, sizeof(int), Tri);
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    qsort (tab, TAILLE, sizeof *tab, Tri);
    ou
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    qsort (tab, sizeof tab/sizeof *tab, sizeof *tab, Tri);
    et la fonction de tri :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    int Tri(const void* _a, const void* _b) {
        if (*(int*)_a<*(int*)_b) return 1;
        if (*(int*)_a==*(int*)_b) return 0;
        if (*(int*)_a>*(int*)_b) return -1 ;
    }
    compliqué...
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    int Tri (const void* a, const void* b) 
    {
       int *pa = a;
       int *pb = b;
       return *pa - *pb;
    }
    Pas de Wi-Fi à la maison : CPL

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

Discussions similaires

  1. Réponses: 1
    Dernier message: 25/09/2008, 16h07
  2. Ajuster la taille d'un tableau par rapport à la défintion d'écran
    Par ilcocodrillo dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 18/06/2008, 11h42
  3. [Tableaux] classer un tableau par rapport à un autre
    Par Alexdezark dans le forum Langage
    Réponses: 1
    Dernier message: 13/06/2008, 12h33
  4. Réponses: 4
    Dernier message: 17/03/2008, 11h03
  5. Trier un tableau par rapport à un autre tableau
    Par deaven dans le forum Algorithmes et structures de données
    Réponses: 2
    Dernier message: 02/05/2005, 09h27

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