[C]erreur de segmentation dans une fonction
lami20j Messages postés 21506 Date d'inscription Statut Modérateur, Contributeur sécurité Dernière intervention -
j'ai une erreur de segmentation dans une focntion
voilà l'idée de base ; on creer une fonction du genre : afficheOrigineavecListe(element de ta liste (genre ab), et une liste avec lekel il faut tout afficher)
{ tant que ta liste nest pas vide si lelement de ta liste que tu parcours et different de Origine, alors tu afifche Origine->element et j'appel cette fonction genre avec : ab, et tab[0] pui ab et tab[1], etc...
seq =(Liste **) malloc (NBRSEQ * sizeof(Liste *)); // les tableau des toutes les Nseq
for(i=0; i<NBRSEQ; i++)
{
//GenRA(seq[i], res);
p=seq[i];
while (p!=NULL)
{
printf("%s", p->mot);
for(j=0; j<NBRSEQ; j++)
{
AfficherOrigineListe(p->mot, seq[j]);
}
}
void AfficherOrigineListe(char mot [150], Liste *p)
{
while (p!=NULL)
{
// printf("%s", p->mot);
if(strcmp(p->mot, mot)!=0)_____________________ici l'erreur_____________________
{
printf("%s", p->mot);
printf("->");
printf("%s", mot);
//
}
p=p->suivant;
}
}
j'attends vos reponse
Configuration: Windows Vista Internet Explorer 7.0
- [C]erreur de segmentation dans une fonction
- Fonction si ou - Guide
- Fonction remplacer dans word - Guide
- Une erreur de communication est détectée dans le module de sécurité - Forum TNT / Satellite / Réception
- Erreur player 4001 free - Forum Samsung
- Fonction trier excel - Guide
41 réponses
- 1
- 2
- 3
L'erreur de segmentation provient d'une boucle qui parcourt les listes via seq et p sans filtrer les éléments NULL et sans avancer correctement dans les maillons.
Plusieurs réponses recommandent de traiter uniquement les éléments non nuls du tableau seq et d'éviter d'appeler AfficherOrigineListe sur des pointeurs NULL, en vérifiant seq[i] avant l'appel.
D'autres interventions soulignent que le parcours intérieur doit faire p = p->suivant et que le code doit sortir de la boucle lorsque p est NULL, afin d'éviter les boucles infinies.
Autre nuance utile : vérifier l'initialisation des tableaux seq et leur taille NBRSEQ pour éviter d'accéder à des éléments hors tableau, surtout lors de l'allocation dynamique.
l'erreur est peut être ici.
while (p!=NULL)
{
printf("%s", p->mot);
for(j=0; j<NBRSEQ; j++)
{
AfficherOrigineListe(p->mot, seq[j]);
}
}
La condition sera toujours vraie vu que tu n'incrémentes pas
while (p!=NULL)
{
printf("%s", p->mot);
for(j=0; j<NBRSEQ; j++)
{
AfficherOrigineListe(p->mot, seq[j]);
}
p=p->suivant;
}
for(i=0; i<NBRSEQ; i++){
//GenRA(seq[i], res);
p=seq[i];
while (p!=NULL){
printf("%s", p->mot);
for(j=0; j<NBRSEQ; j++)
AfficherOrigineListe(p->mot, seq[j]);
p=p->suivant;
}
}
if(strcmp(p->mot, mot)!=0)
quand je fait des printf de cette facon
printf("%s\n", p->mot);
printf("%s\n",mot);
if(strcmp(p->mot, mot)!=0)
juste avant le declenchement du message d'erreur , il n'affiche pas ce message printf("%s\n", p->mot);
c'est a dire le probleme vient de p
je sais pas si c'est null ou sa manque une allocation ou autre.
je suis perdue vraiement
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre questionvoid AfficherOrigineListe(char mot [150], Liste *p)
{
while (p!=NULL){
printf("%s -> %s\n", p->mot,mot);
p=p->suivant;
}
}
ya une erruer de segmentation ici : printf("%s -> %s\n", p->mot,mot);
je pense que le probleme vient de p->mot
je vois ça
seq =(Liste **) malloc (NBRSEQ * sizeof(Liste *)); // les tableau des toutes les Nseq
for(i=0; i<NBRSEQ; i++)
{
//GenRA(seq[i], res);
p=seq[i];
Mais je ne vois null part que seq contient quelque chose
tu alloues la mémoire, d'accord mais après????
Pour moi seq ne pointe vers rien du tout
j'ai fait ca
seq =(Liste **) malloc (NBRSEQ * sizeof(Liste *)); // les tableau des toutes les Nseq
for(i =0;i<NBRSEQ-1; i++)
{
seq[i]=NULL;
}
seq[0]=seq2;
mais ca marche pas aussi :(
Tu dis ça // les tableau des toutes les Nseq
Ben, tu n'as qu'à commencer affecter le tableau seq avec tes Nseq et ensuite le traiter
seq =(Liste **) malloc (NBRSEQ * sizeof(Liste *));
tu ne fait qu'allouer de la mémoire pour un tableau de listes
ensuite tu dois faire pointer chaque élément de ton tableau de listes vers une liste
après ça tu pourras parcourir ton tableau de listes
ben comme dis lamij20, t'as rien dans seq.....
peut etre fait un tableau du style:
int i=0;
liste* tab[NBRSEQ];
while(i<=NBRSEQ)
{tab[i]=le_nom_de_ta_liste;
i++;}
@+
C'est à toi de nous dire.
Quand tu crées seq à quoi tu penses qu'il doit contenir?
typedef struct L
{
int freq;
char mot[C_TAILLE_MOT];
struct L *suivant;
} Liste;
voilà ^^
comme ca ca plante : for(i =0;i<NBRSEQ-1; i++)
{
seq[i]=p;
}
En fait quand tu fait ça, tu ne fait que pointer chaque élément de tableau sur la même liste.
Pour chouka
p est un pointeur de type Liste
Justement, où sont ces listes de mots
seq[0]=ListeDeMot1; seq[1]=ListeDeMot2; . . . seq[NBRSEQ]=ListeDeMotNBRSEQ;
- 1
- 2
- 3