Langage c

omzyaser -  
jisisv Messages postés 3645 Date d'inscription   Statut Modérateur Dernière intervention   -
SVP est ce que vous pouvez m'aider:
je doit faire une fonction ajouterlisteordonnée qui permet d'ajouter un element dans une liste chainée ordonnée mais je sais pas ou se trouve le problème(le programme se plante lors de son execution)
/*
*
*inserer dans une liste ordonnée
*
*/
int insertionListeOrd(char *nom,int val){
Personne *p=(Personne *)malloc(sizeof(Personne));
if(p==NULL) return 0;
else{
strcpy(p->nom,nom);
p->val=val;
if(premier==NULL){
p->svt=NULL;
premier=p;
return 1;
}
else{
Personne *p2=premier;
Personne *p3=premier->svt;
while((strcmp(p2->nom,nom)<0)&&(strcmp(nom,p3->nom)>0)){
p2=p2->svt;
p3=p3->svt;
}
p->svt=p3;
p2->svt=p;
}
}
}
A voir également:

1 réponse

jisisv Messages postés 3645 Date d'inscription   Statut Modérateur Dernière intervention   934
 
Essaye ceci (je n'ai pas tout testé !!)

#include <stdlib.h>
#include <stdio.h>
#include <string.h>
/*
 *
 *inserer dans une liste ordonnée
 *
 */


typedef struct Personne{
  struct Personne *svt;
  int val;
  char *nom;
} Personne;

Personne *insertion(Personne **premier, char *nom, int val){
  Personne *p=(Personne *)malloc(sizeof(Personne));
  if(NULL == p)
    return NULL;
  else{
    p->nom = nom;
    p->val = val;
    if(NULL == *premier){
      p->svt = NULL;
      *premier = p;
      return p;
    }
    else{
      Personne *p2 = *premier;
      Personne *p3 = (*premier)->svt;
      while ( (strcmp(p2->nom,nom)<0) && (NULL != p3) &&  (strcmp(nom,p3->nom)>0)) {
	p2 = p2->svt;
	p3 = p3->svt;
      }
      p->svt=p3;
      p2->svt=p;
    }
    return p;
  }
}

int main(int argc, char *argv[]) {

  Personne *liste = NULL, *qqun;

  qqun = insertion( &liste, "Brian Kernighan", 1942);
  qqun = insertion( &liste, "Linus Torvalds", 1969);
  qqun = insertion( &liste, "James Gosling", 1955);
  if(NULL != qqun) {
    printf("%s\n", liste->svt->nom);
    // doit afficher "James Gosling"
  } 
  return 0;
}
johand@osiris:~/src/ccm$ gcc -Wall -o 20916919-langage-c -g 20916919-langage-c.c
johand@osiris:~/src/ccm$ ./20916919-langage-c 
James Gosling


Johan

0