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 de chaine de caractère avec fgets


Sujet :

C

  1. #1
    Membre régulier Avatar de clampin
    Homme Profil pro
    Inscrit en
    Février 2005
    Messages
    96
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : Belgique

    Informations forums :
    Inscription : Février 2005
    Messages : 96
    Points : 105
    Points
    105
    Par défaut Tri de chaine de caractère avec fgets
    Bonjour,

    j'ai commencé l'étude des tris de caractère (a, b, c) pour par exemple trier des noms.


    j'ai dans mon programme une fonction d'entrée des noms, une fonction de tri, et une fonction d'affichage de la liste triée. (c'est peut être pas le plus simple).

    voici le code complet de mon petit programme (74 lignes)

    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
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
     
    /* L'utilisateur tape une suite d'entrées au clavier, elles
    * sont triées puis affichées à l'écran */
     
    #include <stdio.h>
    #include <stdlib.h>
    #include <string.h>
     
    #define MAXLINE 25 /*pas plus de 25 phrases */
     
    	int get_lines(char *lines[]);         /*entrée des phrases */
    void sort(char *p[], int n);          /*tris des phrases */
    void print_strings(char *p[], int n); /*réaffichage à l'écran */
     
    char *lines[MAXLINE];
     
    int main()
    {
    	int number_of_lines;
     
    	/*lire les phrases au clavier */
     
    	number_of_lines = get_lines(lines);
     
    	if (number_of_lines < 0)
    	{
    		puts("Erreur de mémoire");
    		exit(-1);
    	}
     
    	sort(lines, number_of_lines);
    	print_strings(lines, number_of_lines);
     
    	return 0;
    }
     
    int get_lines(char *lines[])
    {
    	int n = 0;
    	char buffer[80]; /*Mémoire de stockage temporaire */
     
    	puts("Tapez les phrases une par une");
    	puts("Terminez par un simple appui sur Entrée");
     
    	while((n < MAXLINE) && (gets(buffer) !=0) && (buffer[0] !='\0'))
    	{
    		if ((lines[n] = (char *)malloc(strlen(buffer)+1)) == NULL)
    			return -1;
    		strcpy(lines[n++], buffer);
    	}
     
    	return n;
    } /*fin de get_lines() */
     
    void sort(char *p[], int n)
    {
    	int a,b;
    	char *x;
     
    	for (a = 1; a < n; a++)
    		for (b = 0; b < n-1; b++)
    	{if (strcmp(p[b],p[b+1] ) > 0)
    	{ x = p[b];
    		p[b] = p[b+1];
    		p[b+1] = x;
    	}
    }
    } /*fin de sort() */
     
    void print_strings(char *p[], int n)
    { int count;
     
    	for(count = 0; count <n; count++)
    		printf("%s\n", p[count]);
    } /*fin de print_strings() */
    dans ma fonction get_lines j'utilise pour l'instant gets (oui, je sais c'est mal). si je change en voulant utiliser fgets (comme recommandé dans ce forum a raison, ça compile pas).

    Pourquoi ? car d'habitude elle ne pose pas de problème.

  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 518
    Points
    41 518
    Par défaut
    Montre comment tu cherches à utiliser fgets().
    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 régulier Avatar de clampin
    Homme Profil pro
    Inscrit en
    Février 2005
    Messages
    96
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : Belgique

    Informations forums :
    Inscription : Février 2005
    Messages : 96
    Points : 105
    Points
    105
    Par défaut
    hello (again)

    Et bien voici comment j'utilise ma fonction avec fgets...

    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 get_lines(char *lines[])
    {
    	int n = 0;
    	char buffer[80]; /*Mémoire de stockage temporaire */
     
    	puts("Tapez les phrases une par une");
    	puts("Terminez par un simple appui sur Entrée");
     
    	while((n < MAXLINE) && (fgets(buffer,80,stdin) !=0) && (buffer[0] !='\0'))
    	{
    		if ((lines[n] = (char *)malloc(strlen(buffer)+1)) == NULL)
    			return -1;
    		strcpy(lines[n++], buffer);
    	}
     
    	return n;
    } /*fin de get_lines() */

  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 518
    Points
    41 518
    Par défaut
    Ça devrait compiler, mais tu dois faire gaffe au \n si tu veux le prendre en compte. N'oublie pas qu'avec fgets(), si une ligne est trop grande, le prochain fgets() lira la suite de la ligne.
    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 éprouvé Avatar de orfix
    Homme Profil pro
    Inscrit en
    Avril 2007
    Messages
    707
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Maroc

    Informations professionnelles :
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Avril 2007
    Messages : 707
    Points : 1 132
    Points
    1 132
    Par défaut
    Salut,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    /* Exemple de chaîne lus avec gets : */
    'H' 'E' 'L' 'L' 'O' \0
    /* Exemple de chaîne lus avec fgets : */
    'H' 'E' 'L' 'L' 'O' '\n' '\0'
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    puts("Terminez par un simple appui sur Entrée");
    Avec fgets le simple appui sur entrée donne ceci :
    Ta boucle devrai ressembler plus à :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    	while((n < MAXLINE) && (fgets(buffer,80,stdin) !=0) && (buffer[0] !='\n'))
    @++
    To start press any key. (reading screen) Where's the "any" key? I see Esc, Catarl, and Pig Up. There doesn't seem to be any "any" key. Wo! All this computer hacking is making me thirsty. I think I'll order a Tab. (presses TAB key). -- HOMER --

Discussions similaires

  1. Dégradé sur une chaine de caractères avec 3 a 4 couleurs
    Par avogadro dans le forum Composants VCL
    Réponses: 6
    Dernier message: 31/03/2006, 13h21
  2. Reception chaine de caractère avec recvfrom()
    Par innosang dans le forum C
    Réponses: 5
    Dernier message: 31/12/2005, 14h51
  3. Lecture d'une chaine de caractère avec fgets
    Par mayoouketchup dans le forum Langage
    Réponses: 9
    Dernier message: 22/12/2005, 16h17
  4. Réponses: 17
    Dernier message: 16/12/2005, 09h45
  5. Réponses: 2
    Dernier message: 06/12/2002, 07h50

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