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 :

Chaîne de caractères - Palindrome


Sujet :

C

  1. #1
    Nouveau Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mars 2018
    Messages
    1
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 24
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2018
    Messages : 1
    Points : 1
    Points
    1
    Par défaut Chaîne de caractères - Palindrome
    Bonjour,

    Je doit faire un programme pour dire si un mots ou une phrase est un palimdrome ou non. Pour cela je voudrais faire un tableau avec pour chaque case une lettre, enlever les espaces et remplacer les caractère spéciaux, mais je débute et ne c'est pas du tout comment faire.

    Auriez vous quelques idées pour faire cela ?

    Merci d'avance

  2. #2
    Expert éminent sénior
    Homme Profil pro
    Analyste/ Programmeur
    Inscrit en
    Juillet 2013
    Messages
    4 630
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Analyste/ Programmeur

    Informations forums :
    Inscription : Juillet 2013
    Messages : 4 630
    Points : 10 556
    Points
    10 556
    Par défaut
    Un exemple qui
    1. prend en compte que les caractères ascii
    2. ne prend pas en compte les majuscules
    3. ne prend pas en compte les espaces comme dans "Ésope reste ici et se repose"



    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
    #include <stdio.h>
    #include <string.h>
     
     
    int main(int argc, char* argv[]) {
        char* str1 = "maman";
        char  str2[] = "reliefpfeiler";
        char*  begin_str_ptr;
        char*  end_str_ptr;
        int len;
        unsigned char is_palindrome;
     
    //  First
        len = strlen(str1);
     
        begin_str_ptr = str1;
        end_str_ptr   = (str1 + len - 1);
        is_palindrome = 1;
     
        while(is_palindrome && (begin_str_ptr < end_str_ptr)) {
            printf("cmp : %c and %c\n", (*begin_str_ptr), (*end_str_ptr));
     
            if ((*begin_str_ptr) != (*end_str_ptr)) {
                is_palindrome = 0;
            } else {  }
     
            ++begin_str_ptr;
            --end_str_ptr;
        }
     
        printf("\"%s\" is%s a palindrome\n", str1, ((is_palindrome)? "": " not"));
     
    //  Second
        len = strlen(str2);
     
        begin_str_ptr = str2;
        end_str_ptr   = (str2 + len - 1);
        is_palindrome = 1;
     
        while(is_palindrome && (begin_str_ptr < end_str_ptr)) {
            printf("cmp : %c and %c\n", (*begin_str_ptr), (*end_str_ptr));
     
            if ((*begin_str_ptr) != (*end_str_ptr)) {
                is_palindrome = 0;
            }
     
            ++begin_str_ptr;
            --end_str_ptr;
        }
     
        printf("\"%s\" is%s a palindrome\n", str2, ((is_palindrome)? "": " not"));
    }

  3. #3
    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
    "remplacer les caractères spéciaux", c'est loin d'être trivial, vu que ça impose d'en avoir la liste (qui change d'une locale à l'autre, d'un encodage à l'autre, et l'encodage par défaut change entre Linux et Windows).
    Je suppose que tu parles de remplacer les lettres accentuées par des lettres simples?

    Pour ça donc, la première question serait "es-tu sous Linux ou Windows?" Et si tu es sous Linux, il va falloir faire un petit test pour différencier entre les deux encodages les plus probables (UTF-8 et ISO 8859-1) car ce n'est pas du tout la même chose pour les gérer... Sauf peut-être si on utilise la fonction mbstowcs() pour tout convertir en wchar_t, ce serait probablement la méthode la plus "compatible".
    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.

  4. #4
    Expert éminent sénior
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 690
    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 690
    Points : 30 985
    Points
    30 985
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par Petcho Voir le message
    faire un tableau avec pour chaque case une lettre, enlever les espaces
    En programmation, on ne peut jamais rien enlever. On ne peut que remplacer une valeur par une autre. Si par exemple tu as "toto le haricot", et que tu veux "enlever" les espaces, il te faudra alors "tasser" ton tableau en utilisant deux indices, le premier qui lit et le second qui écrit ce qui a été lu sauf si ce qui a été lu est un espace. Tu auras au final "totoleharicot"
    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]

Discussions similaires

  1. Réponses: 8
    Dernier message: 12/02/2013, 01h08
  2. Réponses: 2
    Dernier message: 18/10/2003, 14h42
  3. Chaînes de caractères
    Par Zazeglu dans le forum C
    Réponses: 3
    Dernier message: 28/08/2003, 16h20
  4. Inverser une chaîne de caractères
    Par DBBB dans le forum Assembleur
    Réponses: 2
    Dernier message: 30/03/2003, 11h09
  5. Réponses: 3
    Dernier message: 09/05/2002, 01h39

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