Aide pour inverser une chaîne de caractère en C [Résolu/Fermé]

Messages postés
42
Date d'inscription
samedi 1 décembre 2012
Statut
Membre
Dernière intervention
17 février 2014
- - Dernière réponse : fiddy
Messages postés
11137
Date d'inscription
samedi 5 mai 2007
Statut
Contributeur
Dernière intervention
18 octobre 2016
- 6 janv. 2014 à 12:14
Bonjour,

En fait voilà je doit effectuer un programme qui a pour but d'inverser une chaîne de caractère :
ex : "chien" ----> "neihc"
Et après de longue recherche sur internet je n'ai rien trouvé ...
J'ai déjà un début de programme mais il ne fonctionne pas ...
Le voilà : #include<stdio.h>
#include<conio.h>
#include<string.h>
#include<stdlib.h>
#include"Header1.h"


void main()
{
inverser_chaine();

}

void inverser_chaine()
{
char chaine[20];
int mot, i=0, mot_2;
char temp;
mot = strlen(chaine);
mot_2 = mot/2;
printf("Entrez le mot : ", mot);
scanf ("%s", mot);
system("pause");
inverser_chaine(&chaine[20]);
}


void inverser_chaine(char chaine[])
{
int mot=0, i=0, mot_2=0;
char temp;
while(i<mot_2)
{
temp = chaine[mot-1-i];
chaine[mot-1-i] = chaine[i];
chaine[i] = temp;
i++;
}
return;
system("pause");
}


Merci d'avance !! =D
Afficher la suite 

1 réponse

Meilleure réponse
Messages postés
11137
Date d'inscription
samedi 5 mai 2007
Statut
Contributeur
Dernière intervention
18 octobre 2016
1592
4
Merci
Bonjour,

Vu toutes les erreurs, je te conseille de revoir les bases.

void main() => int main(void)
Il faut donc un return 0; à la fin du main().

void inverser_chaine()
Tu n'as pas le droit de définir plusieurs fonctions avec des arguments différents. Le C n'est pas du C++. Il faut donc un nom différent.

mot = strlen(chaine);
chaine n'est pas défini. Il faut faire scanf("%19s", chaine); avant.

mot_2 = mot/2;
A quoi sert mot_2 ? Tu ne t'en sers pas.

printf("Entrez le mot : ", mot);
Plutôt : printf("Entrez le mot : "); ou alors printf("Entrez le mot : %d", mot); pour afficher le nombre de lettres de chaine (qui vaudra n'importe quoi car chaine n'est pas initialisé).

system("pause");
Non portable. Utilise plutôt getchar(); Il faudrait d'ailleurs le mettre deux fois pour éliminer le "\n" résidant dans le buffer clavier (reste du scanf("%s", chaine);)

Dans void inverser_chaine(char chaine[])
while(i<mot_2)
i vaut 0, mot_2 vaut 0. 0 n'est pas inférieur à 0, donc la boucle ne sera jamais réalisée...

temp = chaine[mot-1-i];
mot vaut 0, i vaut 0. Donc temp=chaine[-1] => Erreur.

return;
Il sert à rien ton return; Tu es dans un void...

system("pause");
Tout ce qui est placé après le return ne sert à rien puisque cela ne sera jamais exécuté.

Je n'ai même pas regardé si l'algorithme était cohérent. Corrige déjà tout ça. Poste ton nouveau code avec indentation dans la balise "code c" (situé à droite du bouton "souligné").

Dire « Merci » 4

Quelques mots de remerciements seront grandement appréciés. Ajouter un commentaire

CCM 59976 internautes nous ont dit merci ce mois-ci