IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

C Discussion :

Problème avec une liste chainée


Sujet :

C

  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    41
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 41
    Par défaut Problème avec une liste chainée
    Bonjour.

    Je viens de créer un programme censé demander à l'utilisateur d'entrer les valeurs des éléments d'une liste chainée et les afficher.
    Le problème est qu'une fois exécuté, le programme plante lors de la première valeur entrée.
    Selon le débogueur, ce serait une erreur de segmentation.
    Toute aide est la bienvenue.

    Voici mon code:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
     
    #include <stdlib.h>
    #include <stdio.h>
     
     
    typedef struct element
    {
        int val;
        struct element *next;
     
    }element;
     
     
    void afficher_liste(element *liste_chainee);
    void ajout_fin_liste(element **liste_chainee);
     
     
    int main(void)
    {
        element *liste_chainee = NULL;
     
        ajout_fin_liste(&liste_chainee);
        afficher_liste(liste_chainee);
     
        return 0;
    }
     
     
    void ajout_fin_liste(element **liste_chainee)
    {
        int nombre_elements=0, valeur=0;
     
        scanf("%d", &nombre_elements);
     
        element *nouvel_element = (malloc(sizeof(element)));
     
     
        for(; nombre_elements > 0; nombre_elements--)
        {
            scanf("%d", &valeur);
     
            nouvel_element->val = valeur;
            nouvel_element->next = NULL;
     
            element *temp = *liste_chainee;
     
            while(temp->next != NULL)
            {
                temp = temp->next;
            }
     
            temp->next = nouvel_element;
        }
     
    }
     
     
     
    void afficher_liste(element *liste_chainee)
    {
        while(liste_chainee != NULL)
        {
            printf("%d ", liste_chainee->val);
            liste_chainee = liste_chainee->next;
        }
    }

  2. #2
    Membre expérimenté Avatar de Bob.Killer
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    336
    Détails du profil
    Informations personnelles :
    Âge : 44
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 336
    Par défaut
    pour le 1er élément ton pointeur "liste_chainee" est NULL, donc qd tu fais

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    temp = liste_chainee;
     
    while(temp->next != NULL)
    {
         temp = temp->next;
    }
    temp = NULL et tu tentes d'accéder à next.

  3. #3
    Membre chevronné
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    349
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 349
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
            element *temp = *liste_chainee;
     
            while(temp->next != NULL)
    lors du premier appel, *liste_chainee vaut NULL;

    temp->next provoque donc une erreur.

    Il y a peut-être d'autres erreurs, je me suis arrêté à ce 1er problème.

    [EDIT] argh!!! Je suis grillé !

  4. #4
    Membre expérimenté Avatar de Bob.Killer
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    336
    Détails du profil
    Informations personnelles :
    Âge : 44
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 336
    Par défaut
    lol ouai c'est souvent comme ça qd c'est facil

Discussions similaires

  1. Problème avec une liste.
    Par Baban29 dans le forum Général JavaScript
    Réponses: 6
    Dernier message: 26/04/2007, 12h12
  2. STL Problème avec une liste d'instances de class
    Par BruceBoc dans le forum SL & STL
    Réponses: 12
    Dernier message: 16/02/2007, 14h12
  3. Probleme avec une liste chainée
    Par apen2k2 dans le forum C
    Réponses: 7
    Dernier message: 14/12/2006, 16h31
  4. petit probleme avec une liste chainée
    Par kamouminator dans le forum C
    Réponses: 26
    Dernier message: 06/11/2006, 20h18
  5. [Débutant] problème avec une liste déroulante
    Par stan21 dans le forum Access
    Réponses: 3
    Dernier message: 12/07/2006, 14h52

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo