Création liste chainée en C
hamsam2000
Messages postés
1
Date d'inscription
Statut
Membre
Dernière intervention
-
[Dal] Messages postés 6205 Date d'inscription Statut Contributeur Dernière intervention -
[Dal] Messages postés 6205 Date d'inscription Statut Contributeur Dernière intervention -
Bonjour,
Pouvez-vous m'aider car mon programme ne crée pas la Liste
#include <stdio.h> #include <stdlib.h> typedef struct _cellule{ int a; struct _cellule * suiv; } Cellule; Cellule *creer_cellule(int a) { Cellule *ca = (Cellule *) malloc(sizeof(Cellule)); ca->a = a; ca->suiv = NULL; } Cellule *ajouter_en_tete_cellule(Cellule *liste, Cellule *cellule) { cellule->suiv = liste; return cellule; } Cellule *ajouter_en_fin_cellule(Cellule *liste, Cellule *cellule) { Cellule *temp = liste; if (liste == NULL){ return cellule; } temp = cellule; while (temp->suiv) { temp=temp->suiv; } temp->suiv = cellule; return liste; } void ajouter_cellule(int a, Cellule **liste_cellule) { /*A Completer*/ Cellule *cellule = creer_cellule(a); *liste_cellule = ajouter_en_fin_cellule(*liste_cellule, cellule); } void affiche_cellule(Cellule *cellule) { Cellule *temp; temp = cellule; if (cellule == NULL) { printf("la liste est vide"); } else { while(temp != NULL){ printf("%d-->", temp->a); temp = temp->suiv; } } } int main() { Cellule*list_cellule = NULL; int a; for (int i = 0; i < 5; i++) { printf("donner une valeur"); scanf("%d", &a); ajouter_cellule(a, &list_cellule); } affiche_cellule(list_cellule); printf("\n"); return 0; }
A voir également:
- Création liste chainée en C
- Liste déroulante excel - Guide
- Liste déroulante en cascade - Guide
- Creation compte gmail - Guide
- Création site web - Guide
- Media creation tool - Télécharger - Systèmes d'exploitation
2 réponses
Comme le suggère Pierrot, il manque return ca; dans la fonction creer_cellule() car elle ne retourne rien en dépit de son prototype.
Ce n'est pas la seule erreur.
Dans cette fonction :
Cellule *ajouter_en_fin_cellule(Cellule *liste, Cellule *cellule) { Cellule *temp = liste; if (liste==NULL){ return cellule; } temp= cellule; while(temp->suiv){ temp=temp->suiv; } temp->suiv=cellule; return liste; }
En ligne 7 ci-dessus tu écrases le début de la liste que tu avais mis dans temp, avec la nouvelle cellule, ce qui fait que tu ne parcours jamais la liste en réalité. Tu dois retirer cette ligne.