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 :

Tester si la chaîne v est une mots de l'alphabet A={a,b,c}


Sujet :

C

  1. #1
    Membre habitué
    Inscrit en
    Mars 2010
    Messages
    10
    Détails du profil
    Informations forums :
    Inscription : Mars 2010
    Messages : 10
    Par défaut Tester si la chaîne v est une mots de l'alphabet A={a,b,c}
    Bonjour à tous,

    Je voudrais tester si la chaîne v est un mot de l'alphabet A={a,b,c}.

    Le problème, c'est que je veux donner une réponse final si O.K. ou Not O.K., je veux sortir de la boucle si pas O.K. Voila :

    Code C : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    gets(v);
     
    for(i=0;i<strlen(v);i++)
    {
        if( v[i]== 'a'|| v[i]== 'b'|| v[i]== 'c')
            printf("ok\n");
        else
            printf("not ok\n");
    }

  2. #2
    Modérateur
    Avatar de Obsidian
    Homme Profil pro
    Développeur en systèmes embarqués
    Inscrit en
    Septembre 2007
    Messages
    7 424
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Développeur en systèmes embarqués
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2007
    Messages : 7 424
    Par défaut
    Pour sortir de la boucle, tu peux utiliser le mot-clé « break ».

    Ensuite, tu sais que ton mot est défini sur A* si la boucle est allée jusqu'à son terme (autrement dit, si on n'a trouvé aucun caractère n'appartenant pas à A). Il suffit donc de vérifier si i est égal à la longueur de la chaîne :

    Code C : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
        if (i==strlen(v)) printf ("O.K.\n");
        else              printf ("Pas O.K.\n");

  3. #3
    Rédacteur/Modérateur
    Avatar de Trap D
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    4 942
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2003
    Messages : 4 942
    Par défaut
    Pourquoi ne pas faire vraiment du C :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    char *p = NULL;
    ....................
    fgets(v, sizeof(v), stdin);
     
    p = v;
     
    while(*p== 'a'|| *p== 'b'|| *p== 'c')
      p++;
     
    if (*p == 0) 
      printf ("O.K.\n");
    else
      printf ("Pas O.K.\n");
    "La haine seule fait des choix" - Koan Zen
    "Il ne faut pas être meilleur que les autres, il faut être meilleur que soi." Albert Jacquard
    "Ceux qui savent où ils ont posé leur parapluie ne sont pas alcooliques." - pgibonne.
    Faites du Prolog, ça vous changera les idées !
    Ma page Prolog
    Mes codes sources commentés

    Mon avatar : La Madeleine à la veilleuse de Georges de La Tour

  4. #4
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 385
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 385
    Par défaut
    Commenté:
    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
    char v[TAILLE];
    fgets(v, sizeof(v), stdin);
     
    /*On parcoure la chaîne tant qu'on est dans les caractères acceptés*/
    {
      char const *p = v;
     
      /*Note: ceci doit pouvoir être remplacé par un appel
      à la fonction standard strspn(), à laquelle on pense rarement.*/
      while(*p== 'a'|| *p== 'b'|| *p== 'c')
        p++;
     
      /*Si on est jusqu'au bout de la chaîne, c'est OK.*/
      if (*p == '\0') 
        printf ("O.K.\n");
      else
        printf ("Pas O.K.\n");  
    }
    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 averti
    Profil pro
    Inscrit en
    Septembre 2009
    Messages
    15
    Détails du profil
    Informations personnelles :
    Âge : 65
    Localisation : Belgique

    Informations forums :
    Inscription : Septembre 2009
    Messages : 15
    Par défaut Pour les puristes.
    Une solution plus élégante :
    sans sortir d'une boucle par un break
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
            int i;
            i=0;
            while ((i<strlen(v)-1) && (v[i]== 'a' || v[i]== 'b' || v[i]== 'c'))
            {
                    i++;
            }
            if (v[i]=='a' || v[i]=='b' || v[i]=='c')
                    printf("ok\n");
            else
                    printf("not ok\n");

  6. #6
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 385
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 385
    Par défaut
    Ou bien, un peu overkill:
    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
    #include <assert.h>
     
    enum EEtat { ACCEPTE, REFUSE, NORMAL };
     
    enum EEtat Transition(enum EEtat courant, char c)
    {
    	/*Normalement, cette fonction en peut pas être appelée pour les états finaux*/
    	assert(courant==NORMAL);
     
    	switch(c)
    	{
    	case 'a':
    	case 'b':
    	case 'c':
    		return NORMAL;
    	case '\0':
    		return ACCEPTE;
    	default:
    		return REFUSE;
    	}
    }
     
    int Verifier(char const *s)
    {
    	enum EEtat initial = NORMAL;
    	enum EEtat courant = initial;
     
    	while(courant!=ACCEPTE && courant!=REFUSE)
    	{
    		courant = Transition(courant, s);
    		s++;
    	}
     
    	if(courant==ACCEPTE)
    		return 1;
    	else
    		return 0;
    }
    Note: Cet automate accepte les mots vides. Si on veut les refuser, il faut rajouter un état supplémentaire.
    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.

  7. #7
    Rédacteur/Modérateur
    Avatar de Trap D
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    4 942
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2003
    Messages : 4 942
    Par défaut
    Citation Envoyé par Médinoc Voir le message
    /*Note: ceci doit pouvoir être remplacé par un appel
    à la fonction standard strspn(), à laquelle on pense rarement.*/
    Il faudrait déjà la connaître

    PS j'aime bien ta dernière version mais j'ai l'impression qu'il manque un return final à Transition et que tu voulais écrire courant = Transition(courant, *s);
    "La haine seule fait des choix" - Koan Zen
    "Il ne faut pas être meilleur que les autres, il faut être meilleur que soi." Albert Jacquard
    "Ceux qui savent où ils ont posé leur parapluie ne sont pas alcooliques." - pgibonne.
    Faites du Prolog, ça vous changera les idées !
    Ma page Prolog
    Mes codes sources commentés

    Mon avatar : La Madeleine à la veilleuse de Georges de La Tour

  8. #8
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 385
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 385
    Par défaut
    Citation Envoyé par Trap D Voir le message
    PS j'aime bien ta dernière version mais j'ai l'impression qu'il manque un return final à Transition !
    Oups! Corrigé, j'ai rajouté un return REFUSE; dans le cas par défaut.

    Et aussi, note bien qu'ici il n'y a qu'un seul état dans lequel la fonction transition peut être appelée. S'il y en avait eu plusieurs, j'aurais dû mettre tout son contenu dans un switch(courant) (et supprimer l'assertion, bien sûr).
    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.

Discussions similaires

  1. Tester si un chaîne est contenue dans une autre
    Par JonathanF dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 03/10/2011, 21h59
  2. Tester si valeur saisie est une chaîne de caractère
    Par mtxmotorax dans le forum Débuter
    Réponses: 9
    Dernier message: 03/03/2011, 11h25
  3. Extraîre une chaîne qui est entre deux chaînes.
    Par Horrigan dans le forum Langage
    Réponses: 5
    Dernier message: 01/09/2006, 20h01
  4. [C# 2.0]Tester si le string est une date
    Par totoen dans le forum Windows Forms
    Réponses: 7
    Dernier message: 25/04/2006, 17h19
  5. Tester si c'est une nouvelle fenêtre ou non
    Par bigsister dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 01/12/2005, 15h39

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