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

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Février 2007
    Messages
    899
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 899
    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
    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
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 68
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    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

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

    Informations professionnelles :
    Activité : Étudiant

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

  5. #5
    Expert éminent
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 68
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    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

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

    Informations forums :
    Inscription : Février 2007
    Messages : 899
    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 : 46
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Juin 2002
    Messages : 2 165
    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 : 48
    Localisation : Suisse

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

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 499
    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 : 48
    Localisation : Suisse

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

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 499
    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 éclairé
    Profil pro
    Inscrit en
    Février 2007
    Messages
    899
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 899
    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 à +

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

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