begin process at 2008 08 21 05:28:19
1 229 221 membres
52 nouveaux aujourd'hui
14 260 membres club

Vous ne trouvez pas de réponse à votre problème ? Alors posez la question dans le forum.
Souvenez-vous qu'il n'y a jamais de question bête, mais rester dans l'ignorance parce que l'on n'ose pas poser une question, ça c'est une erreur !

Sujet : probleme avec une fonction de jointure des éléments de liste [ Divers / Débutant(e) ] (cyrina84)

probleme avec une fonction de jointure des éléments de liste le 18/07/2008 16:01:21

cyrina84


bonjour à tous, j'ai un gros probleme dans ma fonction en C
cette fonction pren en entrée une liste chainée qui contient des couples de mots (exemple: "bonjour le", "le monde", "le garçon").
cette fonction parcour cette liste chainée afin de produire une nouvelle liste de triple de mots (exemple "bonjour le monde") selon une condition (si le dernier mot de la liste égal au premier) ici, on a par exemple ("bonjour le" et "le monde"): pour produire une nouvelle sequence "bonjour le monde" .
j'espere que c plus ou moin clair :)
Bon, voilà le code de cette fonction:
voidGenNseq(Liste*seq){inti;char*mot;Liste*p;Liste*q;Liste*chaine=NULL;char*moRes;char*moRes1;Liste**tab;char*pointeur;char*copi;char*separateur={" "};char*buff;tab=(Liste**)malloc(20*sizeof(Liste*));tab[0]=seq;buff=tab[0]->mot;printf("%s",tab[0]->mot);//test sur les element des 2seq sil ya une jointureprintf("voila la 3sequence");for(p=seq;p!=NULL;p=p->suivant){for(q=seq->suivant;q!=NULL;q=q->suivant){if(strcmp(dernier(p->mot),premier(q->mot))==0)moRes=(char*)malloc(strlen(p->mot)*sizeof(char));p=seq;strcpy(moRes,p->mot);moRes=enlever_dernier_mot(p->mot);free(moRes);moRes1=strcat(moRes,q->mot);chaine=InsertionEnTete(chaine,p->mot);printf("%s",seq->mot);//printf("%s", chaine->mot);//printf("voila la liste jointe");}}//AfficherListe(chaine);}

Re : probleme avec une fonction de jointure des éléments de liste le 18/07/2008 16:06:37

cyrina84
bonjour à tous, j'ai un gros probleme dans ma fonction en C
cette fonction pren en entrée une liste chainée qui contient des couples de mots (exemple: "bonjour le", "le monde", "le garçon").
cette fonction parcour cette liste chainée afin de produire une nouvelle liste de triple de mots (exemple "bonjour le monde") selon une condition (si le dernier mot de la liste égal au premier) ici, on a par exemple ("bonjour le" et "le monde"): pour produire une nouvelle sequence "bonjour le monde" .
j'espere que c plus ou moin clair
Bon, voilà le code de cette fonction:


void GenNseq(Liste *seq)
{int i;
char *mot;
Liste *p;
Liste *q;
Liste *chaine=NULL;
char *moRes;
char *moRes1;
     Liste ** tab;
     char *pointeur;
     char* copi;
char *separateur = { " " };
char *buff;
    tab = (Liste **) malloc (20 * sizeof(Liste *));
      tab [0]=seq;
      buff =tab[0]->mot;
    printf ("%s", tab[0]->mot);
    //test sur les element des 2seq sil ya une jointure
printf("voila la 3sequence");


for(p=seq;p!=NULL;p=p->suivant){
  for (q=seq->suivant;q!=NULL;q=q->suivant){
   if (strcmp(dernier(p->mot),premier(q->mot)  )==0)
    moRes=(char *)malloc(strlen(p->mot)*sizeof(char));
    p=seq;
  strcpy(moRes,p->mot);
   moRes=enlever_dernier_mot(p->mot);
    free(moRes);

  moRes1=strcat(moRes, q->mot);
     chaine=InsertionEnTete(chaine, p->mot);
  
    



printf("%s", seq->mot);
//printf("%s", chaine->mot);
  //printf("voila la liste jointe");
}
}
//AfficherListe(chaine);
}


Classé sous : fonction, mot, liste, char, seq

Participer à cet échange

Pub



Appels d'offres

Recherche developpeur ...
Budget : 700€
extraction dinformatio...
Budget : 300€
campagne Adwords
Budget : 5 000€

CalendriCode

Août 2008
LMMJVSD
    123
45678910
11121314151617
18192021222324
25262728293031

VS Express FR Gratuit !

VS Express en français et 100% gratuit !

Téléchargements

Logiciels à télécharger sur le même thème :

Boutique

Boutique de goodies CodeS-SourceS