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   -

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:

2 réponses

PierrotLeFou
 

Et comment crée-t'on une liste ?
N'aurais-tu rien oublié dans la fonction qui crée une cellule ?

0
[Dal] Messages postés 6205 Date d'inscription   Statut Contributeur Dernière intervention   1 105
 

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.

0