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 :

Permutation chaîne de caractères par indice


Sujet :

C

  1. #1
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2017
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Tourisme - Loisirs

    Informations forums :
    Inscription : Juin 2017
    Messages : 12
    Points : 12
    Points
    12
    Par défaut Permutation chaîne de caractères par indice
    Bonjour,

    Comment réaliser en C une permutation de ce type :

    Par exemple, la permutation {3, 2, 0, 1} appliquée au mot {A, B, A, C} (un ensemble de caractères) produira le mot {C, A, A, B}. De même, encore p = {2, 1, 3, 0} appliquée a w = {A, B, C, D} produira w' = {C, B, D, A} ??


    Merci

  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 519
    Points
    41 519
    Par défaut
    Mon idée: Tu fais un tableau de structures contenant chacune une lettre et un indice, et tu fais un tri dessus en utilisant l'indice comme clé.
    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
    Expert éminent
    Avatar de Pyramidev
    Homme Profil pro
    Développeur
    Inscrit en
    Avril 2016
    Messages
    1 471
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur

    Informations forums :
    Inscription : Avril 2016
    Messages : 1 471
    Points : 6 110
    Points
    6 110
    Par défaut
    Tu cherches trop compliqué, Médinoc.

    FoolBar, voici un code de départ :
    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
    #include <stdio.h>
     
    void appliquerPermutation(char* resultat, const char* mot, const int* tabPermutation, int taillePermutation)
    {
    	//	une petite boucle effacée dans laquelle j'avais
    	//	rempli les autres caractères du résultat
     
    	resultat[taillePermutation] = '\0'; // Les chaînes du langage C doivent se terminer par '\0'.
    }
     
    int main()
    {
    	const char mot1[5] = "ABAC";
    	const int permutation1[4] = {3, 2, 0, 1};
    	char mot1_apres_permutation[5];
    	appliquerPermutation(mot1_apres_permutation, mot1, permutation1, 4);
    	printf("Le 1er mot apres permutation vaut : %s.\n", mot1_apres_permutation);
     
    	const char mot2[5] = "ABCD";
    	const int permutation2[4] = {2, 1, 3, 0};
    	char mot2_apres_permutation[5];
    	appliquerPermutation(mot2_apres_permutation, mot2, permutation2, 4);
    	printf("Le 2e  mot apres permutation vaut : %s.\n", mot2_apres_permutation);
     
    	return 0;
    }
    Après avoir remplacé mon commentaire dans la fonction appliquerPermutation par une boucle de deux lignes de code, cela m'affiche dans la sortie standard :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Le 1er mot apres permutation vaut : CAAB.
    Le 2e  mot apres permutation vaut : CBDA.
    Je te laisse créer la boucle.

  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 689
    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 689
    Points : 30 983
    Points
    30 983
    Billets dans le blog
    1
    Par défaut
    Bonjour
    Citation Envoyé par Pyramidev Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    void appliquerPermutation(char* resultat, const char* mot, const int* tabPermutation, int taillePermutation)
    {
    	//	une petite boucle effacée dans laquelle j'avais
    	//	rempli les autres caractères du résultat
     
    	resultat[taillePermutation] = '\0'; // Les chaînes du langage C doivent se terminer par '\0'.
    }
    Petite optimisation...
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    void appliquerPermutation(char* resultat, const char* mot, const int* tabPermutation)
    {
    	//	une petite boucle effacée dans laquelle j'avais
    	//	rempli les autres caractères du résultat
     
    	resultat[strlen(mot)] = '\0'; // En effet, pourquoi demander un paramètre qui est calculable ???
    }
    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. [MySQL] Découper une chaîne de caractères par la droite
    Par Hboss dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 14/10/2011, 16h49
  2. [RegEx] Test d'une chaîne de caractère par expression rationnelle
    Par sliderman dans le forum Langage
    Réponses: 6
    Dernier message: 28/03/2008, 12h51
  3. Remplacer une chaîne de caractéres par une autre
    Par koKoTis dans le forum Linux
    Réponses: 6
    Dernier message: 15/10/2007, 09h00
  4. Scinder une chaîne de caractère par rapport à un séparateur
    Par Tontorise dans le forum Langage SQL
    Réponses: 3
    Dernier message: 09/07/2007, 13h28
  5. Réponses: 8
    Dernier message: 15/07/2006, 18h59

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