Posez votre question Signaler

C comparaison caracteres

frizou11 - Dernière réponse le 17 févr. 2011 à 02:57
salut tout le monde
bon je bloque sur un truc tout bete:
je suis en langage C et je cherche a comparer 2 caractere
donc j'ai deux chaines de caracteres temp et longueur
longueur est vide et temp comtient un truc du genre "240 60"
et dans longueur je souhaite recopier jsute "240"
alors voici mon code (enfin un morceau) :

int i=0;
while(strcmp(temp[i], " ") != 0)
{
strcpy(longueur[i], temp[i]);
i++;
}

et avec ca j'obtiens une "fault segmentation" aieee.........
aidez moi svp !!!
Lire la suite 

C comparaison caracteres »

8 réponses
Réponse
+2
moins plus
tu as attribué une valeur à longueur avant de modifier ?
tu as déclaré une longueur de chaine suffisament importante pour longueur ?
Ajouter un commentaire
Réponse
+1
moins plus
a mon avis change

strcpy(longueur[i], temp[i]);

par

longueur[i]=temp[i];

je pense que comme tu compares deux caractères le strcpy ne sert à rien
Ajouter un commentaire
Réponse
+1
moins plus
salut tout le monde,
j'ai eu le même probleme, moi j'ai tester le premier paramettre temp[i], s'il est NULL ça donne "fault segmentation" , et ça marche bien,

j'espere que e ça va t'aider.
Ajouter un commentaire
Réponse
+0
moins plus
strcmp doit prendre 2 chaines en paramètres, or le premier param que tu as mis est un caractere, et non une chaine.
En ce qui concerne le strcpy, arth a raison.

Au final, ça devrait ressembler à quelque chose comme ça :
int i=0;
int t;
t = strlen(temp);
for(i=0 ;  ( i < t) && (temp[i] != ' ') , i++ )
{
  longueur[i] = temp[i];
}
longueur[i] = '\0'; // caractere de fin de chaine


Dans ce cas, je suppose que ton tableau de caractère longueur était déjà alloué (et que tu as prévu suffisament de caractères).

frizou11 - 21 nov. 2005 à 14:25
SAlut

deja de savoir retrouver la lettre a supprimé est la 1ere etape, mais il ne faut pas oublier de sauvegarder la position de ta lettre a supprimer dans le mot (dans ton exemple la position sera 3)
ensuite tu parcours ton mot en ne touchant a rien juqu'a ta position -1
puis a partir de position jusqu'a la longueur de ton mot -1 (car ton mot est reduit d'une lettre) tu affectes la lettre suivante
dans ce genre

mot[i] = mot[i+1]

et qd tu es a la fin et que t'as affecté ta derniere lettre, tu dis que ton mot est terminé :
mot[longueur] = '\0'

voila,
c pas super boen expliqué mais la solution est la...
super blaireauPof - 21 nov. 2005 à 15:52
je sui sur un exo du meme genre que toi.
je te laisse mon prog, normalmen il fonctionne:

char chaine1 [30]; // déclaration de la premiere chaine
int L; // declaration de la variable de comptage

cout<<"entrez un premier texte : ";
gets(chaine1); // sasie de la chaine

for (L=0;chaine1 [L]!='\0';L++); // comptage des caracteres
{
cout<<"Votre texte comporte "<<L<<" caracteres\n\n";
}



char chaine2[30]; // déclaration d'une deuxieme chaine
int C; //déclaration d'une variable de comparaison

cout<<"entrez second texte : ";
gets(chaine2); // sasie de la chaine2

for(C=0;C==L;C++);
{
if(chaine1[C]==chaine2[C])
{
cout<<"les textes sont identiques\n\n";
}
else
{
cout<<"les textes ne sont pas identiques\n\n";
youssef evo - 17 févr. 2011 à 02:57
salut
je viens de tomber sur ce sujet et moi je voulais savoir un truc:
si je veux comparer deux chaines caractères ......comment faire???
ex :
chaine1 = heureux;
chaine2 = bonjour;
est ce que je doit faire strict ?
if (chaine1==chaine2) then
.............................
...........................
merci!

Pof
Ajouter un commentaire
Ce document intitulé « C comparaison caracteres » issu de CommentCaMarche (www.commentcamarche.net) est mis à disposition sous les termes de la licence Creative Commons. Vous pouvez copier, modifier des copies de cette page, dans les conditions fixées par la licence, tant que cette note apparaît clairement.
Dossier à la une
Passage au tout numérique : quel coût pour les particuliers ?