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 Par Ordre Alphabétique


Sujet :

C

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Lycéen
    Inscrit en
    Mars 2017
    Messages
    9
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Lycéen

    Informations forums :
    Inscription : Mars 2017
    Messages : 9
    Points : 7
    Points
    7
    Par défaut Tri Par Ordre Alphabétique
    Bonjour, je suis en train de faire un dictionnaire et j'aimerais pouvoir trier dans l'ordre alphabétique les mots du dictionnaire, les mots de mon dictionnaire sont contenu dans un .txt j'ai donc mis le contenu du .txt dans un tableau pour pouvoir le triller avec un qsort(), mais des que j'utilise la fonction mon programme crash et je ne trouve pas la cause

    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
    static int compare (void const *a, void const *b)
    {
       char const *const *pa = a;
       char const *const *pb = b;
     
       return strcmp (*pa, *pb);
    }
     
    void trieAlphabetique()
    {
    	FILE* fichier = NULL;
    	char chaine[TAILLE_MAX] = "";
    	char dico[NOMBRE_MAX_LIGNES][TAILLE_MAX];
    	long i=0;
    	fichier = fopen("dico.txt", "r");
     
    	if (fichier != NULL)
    	{
    		while (fgets(chaine, TAILLE_MAX, fichier) != NULL)
    		{
    			strcpy(dico[i],chaine);
    			i++;
    		}
    		fclose(fichier);
    	}
        qsort (dico, sizeof dico / sizeof *dico, sizeof *dico, compare);
     
    	for (i=0; i<strlen(dico); i++)
            printf("%s", dico[i]);
    }

  2. #2
    Expert confirmé
    Inscrit en
    Mars 2005
    Messages
    1 431
    Détails du profil
    Informations forums :
    Inscription : Mars 2005
    Messages : 1 431
    Points : 4 182
    Points
    4 182
    Par défaut
    Tu tries NOMBRE_MAX_LIGNES éléments quel que soit le nombre d'entrées précédemment lues. Dans le lot tu envoies donc probablement des buffers non initialisés à strcmp.

  3. #3
    Futur Membre du Club
    Homme Profil pro
    Lycéen
    Inscrit en
    Mars 2017
    Messages
    9
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Lycéen

    Informations forums :
    Inscription : Mars 2017
    Messages : 9
    Points : 7
    Points
    7
    Par défaut
    Merci pour ta réponse,
    Il faut donc que j'utilise l'allocation dynamique a la place de NOMBRE_MAX_LIGNES pour résoudre le problème ?

  4. #4
    Expert éminent sénior

    Femme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juin 2007
    Messages
    5 189
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Essonne (Île de France)

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

    Informations forums :
    Inscription : Juin 2007
    Messages : 5 189
    Points : 17 141
    Points
    17 141
    Par défaut
    Non, il faut que tu retiennes combien d'éléments sont effectivement lus.
    en l'occurence, tu as déjà i pour cela.
    Et ton while devrait aussi controler que i ne dépasse pas NOMBRE_MAX_LIGNES
    Mes principes de bases du codeur qui veut pouvoir dormir:
    • Une variable de moins est une source d'erreur en moins.
    • Un pointeur de moins est une montagne d'erreurs en moins.
    • Un copier-coller, ça doit se justifier... Deux, c'est un de trop.
    • jamais signifie "sauf si j'ai passé trois jours à prouver que je peux".
    • La plus sotte des questions est celle qu'on ne pose pas.
    Pour faire des graphes, essayez yEd.
    le ter nel est le titre porté par un de mes personnages de jeu de rôle

  5. #5
    Futur Membre du Club
    Homme Profil pro
    Lycéen
    Inscrit en
    Mars 2017
    Messages
    9
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Lycéen

    Informations forums :
    Inscription : Mars 2017
    Messages : 9
    Points : 7
    Points
    7
    Par défaut
    J'ai modifier les paramètres de qsort pour que le nombre d'éléments du tableau à trier soit égale à i, mais le programme crash toujours :
    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
    void trieAlphabetique()
    {
    	FILE* fichier = NULL;
    	char chaine[TAILLE_MAX] = "";
    	char dico[NOMBRE_MAX_LIGNES][TAILLE_MAX];
    	long i=0;
    	fichier = fopen("dico.txt", "r");
     
    	if (fichier != NULL)
    	{
    		while ((fgets(chaine, TAILLE_MAX, fichier) != NULL)&&(i < NOMBRE_MAX_LIGNES))
    		{
    			strcpy(dico[i],chaine);
    			i++;
    		}
    		fclose(fichier);
    	}
        qsort (dico, i, sizeof *dico, compare);
     
    	for (i=0; i<strlen(dico); i++)
            printf("%s", dico[i]);
    }
    et quand j'utilise le debugger il me signale une erreur pour la fonction compare :
    #1 0x401458 compare(a=0x19bca8, b=0x19b8c0) (C:\Users\Flowrey\Documents\Projets IT\C\Dicoperso\fonctions.c:68)

  6. #6
    Expert confirmé
    Inscrit en
    Mars 2005
    Messages
    1 431
    Détails du profil
    Informations forums :
    Inscription : Mars 2005
    Messages : 1 431
    Points : 4 182
    Points
    4 182
    Par défaut
    Tes éléments sont déjà des const char * :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    static int compare (void const *a, void const *b)
    {
       return strcmp (a, b);
    }

  7. #7
    Futur Membre du Club
    Homme Profil pro
    Lycéen
    Inscrit en
    Mars 2017
    Messages
    9
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Lycéen

    Informations forums :
    Inscription : Mars 2017
    Messages : 9
    Points : 7
    Points
    7
    Par défaut
    Merci Beaucoup ! Même si je me sens un peux bête de pas avoir vu ça ^^

  8. #8
    Expert éminent
    Homme Profil pro
    Ingénieur développement matériel électronique
    Inscrit en
    Décembre 2015
    Messages
    1 565
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur développement matériel électronique
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Décembre 2015
    Messages : 1 565
    Points : 7 648
    Points
    7 648
    Par défaut
    Citation Envoyé par ternel Voir le message
    Non, il faut que tu retiennes combien d'éléments sont effectivement lus.
    en l'occurence, tu as déjà i pour cela.
    Et ton while devrait aussi controler que i ne dépasse pas NOMBRE_MAX_LIGNES
    @Flowrey : Il semble que tu n'aie pas pris en compte ces 2 remarques vitales dans ton code

  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
    Citation Envoyé par Matt_Houston Voir le message
    Tes éléments sont déjà des const char * :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    static int compare (void const *a, void const *b)
    {
       return strcmp (a, b);
    }
    Pour être précis, ce sont des const char[TAILLE_MAX].
    Donc a et b sont de type char const (*)[TAILLE_MAX] (encore que je ne sois pas 100% certain d'où le const doive être placé).
    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
    Expert éminent sénior
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 685
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 685
    Points : 30 974
    Points
    30 974
    Billets dans le blog
    1
    Par défaut
    Bonjour
    Citation Envoyé par Matt_Houston Voir le message
    Tes éléments sont déjà des const char * :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    static int compare (void const *a, void const *b)
    {
       return strcmp (a, b);
    }
    Ou alors passer directement strcmp à la fonction qsort...
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  11. #11
    Expert confirmé
    Inscrit en
    Mars 2005
    Messages
    1 431
    Détails du profil
    Informations forums :
    Inscription : Mars 2005
    Messages : 1 431
    Points : 4 182
    Points
    4 182
    Par défaut
    qsort attend un paramètre de type int (*)(const void *, const void *), ce n'est pas le cas de strcmp.

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

Discussions similaires

  1. [MySQL] Une liste déroulante affichant les données d'une requête SHOW par ordre alphabétique
    Par jack_1981 dans le forum PHP & Base de données
    Réponses: 8
    Dernier message: 22/12/2005, 15h53
  2. Affichage par ordre alphabétique
    Par masseur dans le forum Langage
    Réponses: 8
    Dernier message: 08/12/2005, 11h41
  3. Trie par ordre croissant.
    Par slackjayo dans le forum Algorithmes et structures de données
    Réponses: 6
    Dernier message: 22/04/2005, 09h41
  4. Tri par ordre alphabétique
    Par orus8 dans le forum Langage SQL
    Réponses: 6
    Dernier message: 17/04/2003, 19h27
  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