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 champ structure en c


Sujet :

C

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

    Informations forums :
    Inscription : Mai 2009
    Messages : 116
    Points : 49
    Points
    49
    Par défaut tri champ structure en c
    Bonjour,

    J'aimerais savoir comment trier un champ d'une structure en langage c?
    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
    Développe.

    S'agit-il d'un tableau de structures d'un certain type, que tu veux trier selon un certain champ?
    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
    Membre du Club
    Profil pro
    Inscrit en
    Mai 2009
    Messages
    116
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2009
    Messages : 116
    Points : 49
    Points
    49
    Par défaut
    voici la structure:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    typedef struct
       {
           int date_debut;
           int duree;
     
       }tache;
    int main()
    tache job [3]={{5,3},{1,2},{3,4}};
    Je désire trier le champ duree de la structure tache.
    Des idées?

  4. #4
    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
    Citation Envoyé par laureat Voir le message
    Je désire trier le champ duree de la structure tache.
    Non, tu désires trier ton tableau de structures tache nommé job selon le champ duree de la structure tache.

    Le plus simple, c'est utiliser la fonction qsort().
    Tout ce qu'elle demande, c'est quelques informations sur le tableau et une fonction qui compare:
    Code C : 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
    typedef struct
    {
    	int date_debut;
    	int duree;
    } tache;
     
    int CompareTacheParDuree(const void *pcvA, const void *pcvB)
    {
    	const tache *pcA = pcvA;
    	const tache *pcB = pcvB;
    	int res;
     
    	/*Compare simplement le champ durée, sans considération pour le reste.*/
    	res = pcA->duree - pcB->duree;
    	return res;
    }
     
    int main(void)
    {
    	tache job [3]={{5,3},{1,2},{3,4}};
    	qsort(job, 3, sizeof(tache), CompareTacheParDuree);
    }
    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.

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Mai 2009
    Messages
    116
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2009
    Messages : 116
    Points : 49
    Points
    49
    Par défaut
    Merci c'est gentil de votre part!

  6. #6
    Membre régulier
    Étudiant
    Inscrit en
    Novembre 2008
    Messages
    146
    Détails du profil
    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2008
    Messages : 146
    Points : 97
    Points
    97
    Par défaut
    bonjour
    j'ai une question a propos la qsort() .Est ce que cette fonction Peut trié selon trois champ ? 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
     
    typedef struct CITOYEN
    {
    char nom[10] ;
    char prenom[20];
    int cin;
    int jour;
    int mois;
    int annee;
    int numrue ;
    char cite[15] ;
    char ville[20];
    int codp;
    }cit;
    cit t[i];
    le problème
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    t[i].annee == t[i+1].annee
    alors n passe a la dexième condition :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    t[i].mois== t[i+1].mois
    sinon en passe a la troisième condition :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    t[i].jour== t[i+1].jour
    sinon quelle et la solution ? quel fo l'utiliser ?
    merci bien d'anance

  7. #7
    Membre expérimenté Avatar de plxpy
    Homme Profil pro
    Ingénieur géographe
    Inscrit en
    Janvier 2009
    Messages
    792
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 59
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur géographe
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Janvier 2009
    Messages : 792
    Points : 1 481
    Points
    1 481
    Par défaut
    La fonction qsort effectue le tri à partir de la fonction de comparaison (de deux éléments) que tu lui fournis.

    Reprends le code envoyé par Medinoc et adapte (et renomme ?) la fonction qu'il appelait CompareTacheParDuree à ton cas (comparaison sur les 3 champs, année puis mois puis jour)
    "La simplicité ne précède pas la complexité, elle la suit." - Alan J. Perlis
    DVP ? Pensez aux cours et tutos, ainsi qu'à la FAQ !

  8. #8
    Membre régulier
    Étudiant
    Inscrit en
    Novembre 2008
    Messages
    146
    Détails du profil
    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2008
    Messages : 146
    Points : 97
    Points
    97
    Par défaut
    merci pour la réponse
    je vais voir comment l'adopter le tri selon deux condition de deux champs d'une structure est relativement simple mais tri sur trois conditions pffff sur tout ce problème (àge) il est un peux difficile

  9. #9
    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
    Eh bien typiquement, on obtient un truc de ce genre:
    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
    int CompareCitoyenParDate(const void *pcvA, const void *pcvB)
    {
    	const cit *pcA = pcvA;
    	const cit *pcB = pcvB;
    	int res;
     
    	res = pcA->annee - pcB->annee;
    	if(res != 0)
    		return res;
     
    	res = pcA->mois - pcB->mois;
    	if(res != 0)
    		return res;
     
    	res = pcA->jour - pcB->jour;
    	if(res != 0)
    		return res;
     
    	return 0;
    }
    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.

  10. #10
    Membre régulier
    Étudiant
    Inscrit en
    Novembre 2008
    Messages
    146
    Détails du profil
    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2008
    Messages : 146
    Points : 97
    Points
    97
    Par défaut
    merci bcp voila se que je veux maintenant au

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

Discussions similaires

  1. [AC-2007] Ordre de tri champ alphanumérique
    Par pppa1 dans le forum Access
    Réponses: 4
    Dernier message: 31/07/2011, 10h07
  2. [AC-2010] problème tri champs calculé de date
    Par Sefrou dans le forum VBA Access
    Réponses: 4
    Dernier message: 23/06/2011, 13h19
  3. [XSLT] Gros souci de tri sur structure arborescente
    Par stujava dans le forum XSL/XSLT/XPATH
    Réponses: 1
    Dernier message: 25/03/2010, 17h49
  4. Tri de structure
    Par Esil2008 dans le forum Langage
    Réponses: 6
    Dernier message: 10/10/2008, 12h15
  5. Champs structure verrouillés
    Par Remtimes dans le forum 4D
    Réponses: 2
    Dernier message: 13/08/2007, 16h14

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