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 :

boucle while simple


Sujet :

C

  1. #1
    Membre actif
    Profil pro
    Inscrit en
    Février 2007
    Messages
    778
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 778
    Points : 217
    Points
    217
    Par défaut boucle while simple
    Débutant en C : voici une boucle simple while :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    while (printf("voulez-vous-continuer ?O/N\n"),scanf("%c",&rep),rep=='O')
     
    	 {
    	 printf("while%c\n",rep);
     
    	 }
    mon problème est que à la première exécution si je rentre "O" il exécute bien la boucle et au second passage il affiche "voulez-vous-continuer ?O/N" puis s'arrête sans exécuter la boucle.Là j'avoue je ne comprends pas ! Si quelqu'un peut m'aiguiller
    Merci à tous A +

  2. #2
    Inactif  
    Inscrit en
    Mars 2006
    Messages
    352
    Détails du profil
    Informations forums :
    Inscription : Mars 2006
    Messages : 352
    Points : 292
    Points
    292
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    do
     printf("Voulez-vous continuer ? O/N \n");
     scanf("%c", &rep);
    while (rep == 'O');
    Si rep différent de 'O', on sort de la boucle.
    J'espère avoir répondu à la question.
    Au revoir.

  3. #3
    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
    Citation Envoyé par xeron33 Voir le message
    Débutant en C : voiçi une boucle simple while :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    while (printf("voulez-vous-continuer ?O/N\n"),scanf("%c",&rep),rep=='O')
     
    	 {
    	 printf("while%c\n",rep);
     
    	 }
    mon problème est que à la première exécution si je rentre "O" il exécute bien la boucle et au second passage il affiche "voulez-vous-continuer ?O/N" puis s'arrête sans exécuter la boucle.Là j'avoue je ne comprends pas ! Si quelqu'un peut m'aiguiller
    Le problème de scanf() avec "%c", c'est qu'il ne lit qu'un caractère à la fois alors que tu en as entré 2 ("O\n"). Au tour suivant, il lit le \n sans s'arréter...

    http://emmanuel-delahaye.developpez.com/notes.htm#fgetc

    Il est déconseillé d'utiliser scanf() si on ne le maitrise pas. Il est conseillé d'utiliser fgets().

    http://emmanuel-delahaye.developpez....tes.htm#saisie
    http://emmanuel-delahaye.developpez....s.htm#fichiers
    Pas de Wi-Fi à la maison : CPL

  4. #4
    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
    Citation Envoyé par sidahmed Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    do
     printf("Voulez-vous continuer ? O/N \n");
     scanf("%c", &rep);
    while (rep == 'O');
    Si rep différent de 'O', on sort de la boucle.
    Ca cache le problème, mais ça ne le résout pas...

    http://emmanuel-delahaye.developpez.com/notes.htm#fgetc
    Pas de Wi-Fi à la maison : CPL

  5. #5
    Membre éprouvé
    Avatar de Freed0
    Profil pro
    Étudiant
    Inscrit en
    Mars 2005
    Messages
    635
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2005
    Messages : 635
    Points : 953
    Points
    953
    Par défaut
    Ca manque d'accolades aussi...

  6. #6
    Membre actif
    Profil pro
    Inscrit en
    Février 2007
    Messages
    778
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 778
    Points : 217
    Points
    217
    Par défaut
    Citation Envoyé par Emmanuel Delahaye Voir le message
    Le problème de scanf() avec "%c", c'est qu'il ne lit qu'un caractère à la fois alors que tu en as entré 2 ("O\n"). Au tour suivant, il lit le \n sans s'arréter...

    http://emmanuel-delahaye.developpez.com/notes.htm#fgetc

    Il est déconseillé d'utiliser scanf() si on ne le maitrise pas. Il est conseillé d'utiliser fgets().

    http://emmanuel-delahaye.developpez....tes.htm#saisie
    http://emmanuel-delahaye.developpez....s.htm#fichiers
    J'ai suivi ton conseil et j'ai aussi compris le problème du scanf(entrée de "O" puis de "\n") et suis allé sur ton site parlant de fgets mais je n'arrive pas à mes fins voiçi le code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    char rep[1];
     while (printf("voulez-vous-continuer ?O/N %c\n",rep),fgets(rep,sizeof rep,stdin),rep=='O')
     
    	 {
    	 printf("while%c\n",rep);
     
    	 }
    à la compil j'ai l'erreur suivante :comparaison between pointer and integer
    Si tu peux m'aiguiller encore merçi à toi et à tous les autres qui particpent au forum A +

  7. #7
    gl
    gl est déconnecté
    Rédacteur

    Homme Profil pro
    Inscrit en
    Juin 2002
    Messages
    2 165
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Juin 2002
    Messages : 2 165
    Points : 4 637
    Points
    4 637
    Par défaut
    Citation Envoyé par xeron33 Voir le message
    à la compil j'ai l'erreur suivante :comparaison between pointer and integer
    Le test a effectuer n'est pas rep == 'O' mais rep[0] == 'O'.

    En outre, ton code serait certainement beaucoup plus clair en utilisant une boucle do{} while(); et en sortant l'invite et la saisie du test.
    Il serait aussi preferable de tester le retour de fgets() et de vider le buffer d'entree suite au fgets() (afin de gerer les saisies de plus d'un caractere qui laisseraient de chose dans ce buffer).

  8. #8
    Expert confirmé
    Avatar de Thierry Chappuis
    Homme Profil pro
    Enseignant Chercheur
    Inscrit en
    Mai 2005
    Messages
    3 499
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : Suisse

    Informations professionnelles :
    Activité : Enseignant Chercheur
    Secteur : Industrie Pharmaceutique

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 499
    Points : 5 360
    Points
    5 360
    Par défaut
    Citation Envoyé par xeron33 Voir le message
    J'ai suivi ton conseil et j'ai aussi compris le problème du scanf(entrée de "O" puis de "\n") et suis allé sur ton site parlant de fgets mais je n'arrive pas à mes fins voiçi le code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    char rep[1];
     while (printf("voulez-vous-continuer ?O/N %c\n",rep),fgets(rep,sizeof rep,stdin),rep=='O')
     
    	 {
    	 printf("while%c\n",rep);
     
    	 }
    à la compil j'ai l'erreur suivante :comparaison between pointer and integer
    Si tu peux m'aiguiller encore merçi à toi et à tous les autres qui particpent au forum A +
    Je n'ai pas beaucoup de temps, mais si tu désires saisir un unique caractère '0' ou N' avec fgets(), le tableau rep doit contenir au minimum 3 cases: une pour le caractère 'O' ou 'N', une pour '\n' et une pour '\0'.


    Thierry
    "The most important thing in the kitchen is the waste paper basket and it needs to be centrally located.", Donald Knuth
    "If the only tool you have is a hammer, every problem looks like a nail.", probably Abraham Maslow

    FAQ-Python FAQ-C FAQ-C++

    +

  9. #9
    Expert confirmé
    Avatar de Thierry Chappuis
    Homme Profil pro
    Enseignant Chercheur
    Inscrit en
    Mai 2005
    Messages
    3 499
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : Suisse

    Informations professionnelles :
    Activité : Enseignant Chercheur
    Secteur : Industrie Pharmaceutique

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 499
    Points : 5 360
    Points
    5 360
    Par défaut
    Voici une bonne manière de faire 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
    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
    #include <stdio.h>
    #include <stdlib.h>
    #include <ctype.h>
    #include <string.h>
     
    void fclean(char *s_buffer, FILE *stream);
     
    int main(void)
    {
        char answer[3] = "";
        char *p_eof = NULL;
     
        do
        {
            /* On commence par afficher l'invite */
            printf("Voulez-vous continuer? (o/n) ");
            fflush(stdout);
     
            /* Saisie: p_eof reçoit la valeur NULL si la fin de fichier est
               rencontrée sans qu'aucun autre caractère ait été saisi. */
            if ((p_eof = fgets(answer, sizeof answer, stdin)) != NULL)
            {
                /* Après usage de fgets() on vérifie que la saisie n'a pas été
                   tonquée et, si nécessaire, on nettoie le flux d'entrée standard.
                */
                fclean(answer, stdin);
                if (tolower((unsigned char) answer[0]) == 'o')
                {
                    printf("While %c\n", answer[0]);
                }
            }
     
        } while (tolower((unsigned char) answer[0]) != 'n' && p_eof != NULL);
     
        return EXIT_SUCCESS;
    }
     
    /* Vérifie que la saisie avec fgets() n'a pas été tronquée. Si tel est le cas.
       le caractère de fin de ligne est remplacé par le caractère nul. Sinon, le
       tampon du flux d'entrée stream est nettoyé.
    */
    void fclean(char *s_buffer, FILE *stream)
    {
        if (s_buffer != NULL)
        {
            /* On teste la présence du caractère de fin de ligne */
            char *pc = strchr(s_buffer, '\n');
     
            if (pc != NULL)
            {
                /* La saisie est complète: on remplace '\n' par '\0' */
                *pc = 0;
            }
            else /* La saisie a été tronquée: on vide le tampon de stdin */
            {
                int c;
                while ((c = fgetc(stream)) != '\n' && c != EOF)
                {
                    /* Cette boucle ne fait rien */
                    continue;
                }
            }
        }
    }
    Une autre solution (à mon avis plus simple dans ce cas) utilisant la fonction fgetc() pour la saisie d'un caractère unique:

    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
    #include <stdio.h>
    #include <stdlib.h>
    #include <ctype.h>
     
    void fpurge(FILE *stream);
     
    int main(void)
    {
        int answer;
     
        do
        {
            printf("Voulez-vous continuer? (o/n) ");
            fflush(stdout);
     
            if ((answer = fgetc(stdin)) != '\n' && answer != EOF)
            { /* La saisie n'est pas vide */
     
                /* On teste la réponse de l'utilisateur */
                if (tolower(answer) == 'o')
                {
                    printf("While %c\n", answer);
                }
     
                /* On doit encore purger le tampon du flux d'entrée standard */
                fpurge(stdin);
            }
        } while (tolower(answer) != 'n' && answer != EOF);
     
        return EXIT_SUCCESS;
    }
     
    /* Purge le flux stream */
    void fpurge(FILE *stream)
    {
        int c;
        while ((c = fgetc(stdin)) != '\n' && c != EOF)
        {
            continue;
        }
    }
    N'hésite pas à poser des questions si tu ne comprends pas.

    Thierry
    "The most important thing in the kitchen is the waste paper basket and it needs to be centrally located.", Donald Knuth
    "If the only tool you have is a hammer, every problem looks like a nail.", probably Abraham Maslow

    FAQ-Python FAQ-C FAQ-C++

    +

  10. #10
    Membre actif
    Profil pro
    Inscrit en
    Février 2007
    Messages
    778
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 778
    Points : 217
    Points
    217
    Par défaut
    Citation Envoyé par Thierry Chappuis Voir le message
    Voici une bonne manière de faire 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
    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
    #include <stdio.h>
    #include <stdlib.h>
    #include <ctype.h>
    #include <string.h>
     
    void fclean(char *s_buffer, FILE *stream);
     
    int main(void)
    {
        char answer[3] = "";
        char *p_eof = NULL;
     
        do
        {
            /* On commence par afficher l'invite */
            printf("Voulez-vous continuer? (o/n) ");
            fflush(stdin);
     
            /* Saisie: p_eof reçoit la valeur NULL si la fin de fichier est
               rencontrée sans qu'aucun autre caractère ait été saisi. */
            if ((p_eof = fgets(answer, sizeof answer, stdin)) != NULL)
            {
                /* Après usage de fgets() on vérifie que la saisie n'a pas été
                   tonquée et, si nécessaire, on nettoie le flux d'entrée standard.
                */
                fclean(answer, stdin);
                if (tolower((unsigned char) answer[0]) == 'o')
                {
                    printf("While %c\n", answer[0]);
                }
            }
     
        } while (tolower((unsigned char) answer[0]) != 'n' && p_eof != NULL);
     
        return EXIT_SUCCESS;
    }
     
    /* Vérifie que la saisie avec fgets() n'a pas été tronquée. Si tel est le cas.
       le caractère de fin de ligne est remplacé par le caractère nul. Sinon, le
       tampon du flux d'entrée stream est nettoyé.
    */
    void fclean(char *s_buffer, FILE *stream)
    {
        if (s_buffer != NULL)
        {
            /* On teste la présence du caractère de fin de ligne */
            char *pc = strchr(s_buffer, '\n');
     
            if (pc != NULL)
            {
                /* La saisie est complète: on remplace '\n' par '\0' */
                *pc = 0;
            }
            else /* La saisie a été tronquée: on vide le tampon de stdin */
            {
                int c;
                while ((c = fgetc(stream)) != '\n' && c != EOF)
                {
                    /* Cette boucle ne fait rien */
                    continue;
                }
            }
        }
    }
    Une autre solution (à mon avis plus simple dans ce cas) utilisant la fonction fgetc() pour la saisie d'un caractère unique:

    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
    #include <stdio.h>
    #include <stdlib.h>
    #include <ctype.h>
     
    void fpurge(FILE *stream);
     
    int main(void)
    {
        int answer;
     
        do
        {
            printf("Voulez-vous continuer? (o/n) ");
            fflush(stdin);
     
            if ((answer = fgetc(stdin)) != '\n' && answer != EOF)
            { /* La saisie n'est pas vide */
     
                /* On teste la réponse de l'utilisateur */
                if (tolower(answer) == 'o')
                {
                    printf("While %c\n", answer);
                }
     
                /* On doit encore purger le tampon du flux d'entrée standard */
                fpurge(stdin);
            }
        } while (tolower(answer) != 'n' && answer != EOF);
     
        return EXIT_SUCCESS;
    }
     
    /* Purge le flux stream */
    void fpurge(FILE *stream)
    {
        int c;
        while ((c = fgetc(stdin)) != '\n' && c != EOF)
        {
            continue;
        }
    }
    N'hésite pas à poser des questions si tu ne comprends pas.

    Thierry
    Bonjour Thierry et merçi pour tes tuyaux. J'ai essayé pour l'instant ton code pour fgets mais tu utilises l'instruction et le compilateur n'est pas d'accord car "undeclared".Je suppose que EXIT_SUCCESS est une étiquette mais je la vois pas dans ton code. Je connais la fonction EXIT mais pas EXIT_SUCCESS.
    D'autre part l'instruction suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    if (tolower((unsigned char) answer[0]) == 'o')
    m'interpèle... c'est quoi "tolower" ?
    Merçi de m'aiclairer à +

  11. #11
    Membre actif
    Profil pro
    Inscrit en
    Février 2007
    Messages
    778
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 778
    Points : 217
    Points
    217
    Par défaut
    Citation Envoyé par xeron33 Voir le message
    Bonjour Thierry et merçi pour tes tuyaux. J'ai essayé pour l'instant ton code pour fgets mais tu utilises l'instruction et le compilateur n'est pas d'accord car "undeclared".Je suppose que EXIT_SUCCESS est une étiquette mais je la vois pas dans ton code. Je connais la fonction EXIT mais pas EXIT_SUCCESS.
    D'autre part l'instruction suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    if (tolower((unsigned char) answer[0]) == 'o')
    m'interpèle... c'est quoi "tolower" ?
    Merçi de m'aiclairer à +
    Pardon Thierry je viens de m'appercevoir que j'avais oublié d'inclure certaines bibliothèques que tu avais dans ton code désolé, je te tiens au courant de la suite ... Salut A +

  12. #12
    Membre actif
    Profil pro
    Inscrit en
    Février 2007
    Messages
    778
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 778
    Points : 217
    Points
    217
    Par défaut
    Encore moi malgrès tout avant de quitter le forum je te repose la question car malgrés qu'à la compil ça passe maintenant c'est quoi "tolower" et EXIT_SUCCES ?
    Merçi Thierry et à +

  13. #13
    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
    Citation Envoyé par xeron33 Voir le message
    c'est quoi "tolower" et EXIT_SUCCES ?
    C'est écrit dans ton livre de C...

    Une bonne référence pour les fonctions : http://man.developpez.com

    et pour éviter à l'avenir d'oublier des headers : http://emmanuel-delahaye.developpez....tm#cfg_compilo
    Pas de Wi-Fi à la maison : CPL

  14. #14
    Expert confirmé
    Avatar de Thierry Chappuis
    Homme Profil pro
    Enseignant Chercheur
    Inscrit en
    Mai 2005
    Messages
    3 499
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : Suisse

    Informations professionnelles :
    Activité : Enseignant Chercheur
    Secteur : Industrie Pharmaceutique

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 499
    Points : 5 360
    Points
    5 360
    Par défaut
    Citation Envoyé par xeron33 Voir le message
    Encore moi malgrès tout avant de quitter le forum je te repose la question car malgrés qu'à la compil ça passe maintenant c'est quoi "tolower" et EXIT_SUCCES ?
    Merçi Thierry et à +
    Ma bibliothèque standard définit la constante EXIT_SUCCESS comme étant égale à 0. Par convention, la valeur de cette constante est celle retournée par main lors d'une exécution avec succès.

    L'utilisation de tolower() (déclarée dans le fichier d'en-tête standard ctype.h) permet de convertir les réponses 'O' ou 'N' éventuellement saisies par l'utilisateur en 'o' et 'n', respectivement. C'est un petit sucre ici, car l'invite que lit l'utilisateur est la suivante: "Voulez-vous continuer? (o/n) ". Si on veut que seules les réponses 'o' et 'n' soient acceptées, l'usage de la fonction tolower() est inutile.

    Thierry
    "The most important thing in the kitchen is the waste paper basket and it needs to be centrally located.", Donald Knuth
    "If the only tool you have is a hammer, every problem looks like a nail.", probably Abraham Maslow

    FAQ-Python FAQ-C FAQ-C++

    +

  15. #15
    Expert confirmé
    Avatar de Thierry Chappuis
    Homme Profil pro
    Enseignant Chercheur
    Inscrit en
    Mai 2005
    Messages
    3 499
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : Suisse

    Informations professionnelles :
    Activité : Enseignant Chercheur
    Secteur : Industrie Pharmaceutique

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 499
    Points : 5 360
    Points
    5 360
    Par défaut
    Citation Envoyé par xeron33 Voir le message
    Pardon Thierry je viens de m'appercevoir que j'avais oublié d'inclure certaines bibliothèques que tu avais dans ton code désolé, je te tiens au courant de la suite ... Salut A +
    Comme on peut le lire plusieurs fois par jour sur ce forum... ce ne sont pas des bibliothèques, mais des fichiers d'en-tête.

    Thierry
    "The most important thing in the kitchen is the waste paper basket and it needs to be centrally located.", Donald Knuth
    "If the only tool you have is a hammer, every problem looks like a nail.", probably Abraham Maslow

    FAQ-Python FAQ-C FAQ-C++

    +

  16. #16
    Membre actif
    Profil pro
    Inscrit en
    Février 2007
    Messages
    778
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 778
    Points : 217
    Points
    217
    Par défaut
    Merçi à tous pour vos réponses voiçi ou j'en suis niveau code :
    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
     
     
    #include <stdio.h>
    #include <stdlib.h>
    #include <ctype.h>
    #include <string.h>
    #define LGMAX 100
     
    void fclean(char *s_buffer, FILE *stream);
    int main(void)
    {
      struct enr
      {
    	 char nom[21];
    	 char prenom[16];
    	 int age;
    	 char numtel[12];
      } ;
      struct enr f_enr[LGMAX];
      int i=0;
      char rep[3]="";
      char *p_eof=NULL;
    /*while (printf("voulez-vous-continuer ?O/N %c\n",rep),scanf("%c",&rep),rep=='O')*/
      do 
      {
    	 printf("voulez-vous-continuer ?O/N ");
    	 fflush(stdin);
    	 if ((p_eof = fgets(rep, sizeof rep, stdin)) != NULL)
    	         {
    	             /* Après usage de fgets() on vérifie que la saisie n'a pas été
    	                tonquée et, si nécessaire, on nettoie le flux d'entrée standard.
    	             */
    	            fclean(rep, stdin);
    	             if	 (tolower((unsigned char) rep[0])=='o')
    	             {
    	                 printf("While %c\n", rep[0]);
    	             }
    	         }
     
      }
      while (tolower((unsigned char) rep[0]) != 'n' && p_eof != NULL);
     
    	     return EXIT_SUCCESS;
     
     
    	 /* Vérifie que la saisie avec fgets() n'a pas été tronquée. Si tel est le cas.
    	    le caractère de fin de ligne est remplacé par le caractère nul. Sinon, le
    	    tampon du flux d'entrée stream est nettoyé.
    	 */
    void fclean(char *s_buffer, FILE *stream)
    	 {
    	     if (s_buffer != NULL)
    	     {
    	         /* On teste la présence du caractère de fin de ligne */
    	         char *pc = strchr(s_buffer, '\n');
     
    	         if (pc != NULL)
    	         {
    	             /* La saisie est complète: on remplace '\n' par '\0' */
    	             *pc = '\0';
    	         }
    	         else /* La saisie a été tronquée: on vide le tampon de stdin */
    	         {
    	             int c;
    	  /* fgetc lit le caractère courant du flux int fgetc(FILE * flux)   */      
    	             while ((c = fgetc(stream)) != '\n' && c != EOF)
    	             {
    	                 /* Cette boucle ne fait rien */
    	                  continue;
    	             }
    	         }
    	     }
    	 }
    A la compil pas de problème mais à l'édition de lien j'ai le message suivant :
    "undefined reference to fclean"
    Oui Thierry ta fonction a pour paramètres 2 pointeurs et a pour paramètres rep et stdin , j'ai essayé de mettre 2 pointeurs en paramètres mais non ça marche pas là si tu peux m'aiguiller... Merçi encore pour toutes tes explications A+

  17. #17
    gl
    gl est déconnecté
    Rédacteur

    Homme Profil pro
    Inscrit en
    Juin 2002
    Messages
    2 165
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Juin 2002
    Messages : 2 165
    Points : 4 637
    Points
    4 637
    Par défaut
    Citation Envoyé par xeron33 Voir le message
    A la compil pas de problème mais à l'édition de lien j'ai le message suivant : "undefined reference to fclean"
    Il manque l'accolade fermante a la fin du main.

    En outre que vient faire le fflush(stdin); dans ce code ?
    fflush() n'est defini que sur les flux sortant, fflush(stdin); est donc un comportement indetermine. De plus ici tu voulais certainement force l'affichage de ton texte, c'est donc plutot fflush(stdout);

  18. #18
    Expert confirmé
    Avatar de Thierry Chappuis
    Homme Profil pro
    Enseignant Chercheur
    Inscrit en
    Mai 2005
    Messages
    3 499
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : Suisse

    Informations professionnelles :
    Activité : Enseignant Chercheur
    Secteur : Industrie Pharmaceutique

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 499
    Points : 5 360
    Points
    5 360
    Par défaut
    Citation Envoyé par gl Voir le message
    Il manque l'accolade fermante a la fin du main.

    En outre que vient faire le fflush(stdin); dans ce code ?
    fflush() n'est defini que sur les flux sortant, fflush(stdin); est donc un comportement indetermine. De plus ici tu voulais certainement force l'affichage de ton texte, c'est donc plutot fflush(stdout);
    Je suis responsable de ce fflush(stdin) qui s'est infiltré. C'était une faute de frappe et j'ai corrigé mon post.

    Thierry
    "The most important thing in the kitchen is the waste paper basket and it needs to be centrally located.", Donald Knuth
    "If the only tool you have is a hammer, every problem looks like a nail.", probably Abraham Maslow

    FAQ-Python FAQ-C FAQ-C++

    +

  19. #19
    gl
    gl est déconnecté
    Rédacteur

    Homme Profil pro
    Inscrit en
    Juin 2002
    Messages
    2 165
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Juin 2002
    Messages : 2 165
    Points : 4 637
    Points
    4 637
    Par défaut
    Citation Envoyé par Thierry Chappuis Voir le message
    Je suis responsable de ce fflush(stdin) qui s'est infiltré. C'était une faute de frappe et j'ai corrigé mon post.
    Au temps pour moi, je n'avais pas remarque ce probleme dans ton post.

  20. #20
    Membre actif
    Profil pro
    Inscrit en
    Février 2007
    Messages
    778
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 778
    Points : 217
    Points
    217
    Par défaut
    Citation Envoyé par Thierry Chappuis Voir le message
    Je suis responsable de ce fflush(stdin) qui s'est infiltré. C'était une faute de frappe et j'ai corrigé mon post.

    Thierry
    Bonsoir Thierry, maintenant ça marche j'ai laissé le fflush qui apparement pose pas de problème par contre j'aimerais que tu m'expliques le but du code suivant dans ta fonction fclean mis en italique et en gras en fait si j'ai bien compris tu remplaces "\n" par" \O" dans quel but ?(Qu'elle est l'utilité de "\O" par apport à "\n"? D'ailleurs autre chose dans ton code tu avais : que j'ai remplaçé par et l'une ou l'autre solution marche.
    Merçi si tu peux me préciser tout ça.J'aurai d'autres questions sur cette fonction mais plus tard... Et merçi encore à toi et à tous ceux qui suivent ce site trés utile !!!
    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
    void fclean(char *s_buffer, FILE *stream)
    	 {
    	     if (s_buffer != NULL)
    	     {
    	         /* On teste la présence du caractère de fin de ligne */
    	         char *pc = strchr(s_buffer, '\n');
    	  
    	         if (pc != NULL)
    	         {
    	             /* La saisie est complète: on remplace '\n' par '\0' */
    	             *pc = '\0';
    	         }	         else /* La saisie a été tronquée: on vide le tampon de stdin */
    	         {
    	             int c;
    	  /* fgetc lit le caractère courant du flux int fgetc(FILE * flux)   */      
    	             while ((c = fgetc(stream)) != '\n' && c != EOF)
    	             {
    	                 /* Cette boucle ne fait rien */
    	                  continue;
    	             }
    	         }
    	     }
    	 }

+ Répondre à la discussion
Cette discussion est résolue.
Page 1 sur 3 123 DernièreDernière

Discussions similaires

  1. Problème boucle while + boucle simple
    Par horit dans le forum Général Python
    Réponses: 2
    Dernier message: 26/11/2013, 09h45
  2. Boucle while & read
    Par gibet_b dans le forum Linux
    Réponses: 4
    Dernier message: 29/04/2005, 15h38
  3. boucle while et post incrémentation
    Par tut dans le forum C++
    Réponses: 7
    Dernier message: 10/12/2004, 17h24
  4. [MFC] Dialog dans une boucle while
    Par oxor3 dans le forum MFC
    Réponses: 5
    Dernier message: 23/04/2004, 22h51
  5. [débutant]Documentation? boucle "while"? Session?
    Par o151181 dans le forum Servlets/JSP
    Réponses: 2
    Dernier message: 19/01/2004, 15h20

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