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 :

Les listes chaînées


Sujet :

C

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Novembre 2010
    Messages
    71
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2010
    Messages : 71
    Points : 49
    Points
    49
    Par défaut Les listes chaînées
    Bonjour à tous, je débute en C et je rencontre un petit problème de compréhension concernant les listes chaînés.
    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
     
     
    typedef struct maillon* LISTE;
     
    typedef struct maillon
    {
    	int info;
    	LISTE suivant;
    } MAILLON;
     
    void insert_tete(LISTE *pL, int n)
    {
         LISTE L = (LISTE) malloc(sizeof(MAILLON));
         if(L)
         {
             L->info = n;
             L->suivant = *pL;
             *pL = L;
         }
    }
    Là ou je bloque, c'est que j'ai du mal à comprendre qu'est-ce qu'est vraiment *pL, qui est donné en paramètre.
    Est-ce un maillon de la liste ? La liste entière ? Toutes ces ambiguïtés une fois éclaircis me permettront sans doute de bien comprendre le fonctionnement de cette fonction.

    Merci d'avance de votre réponse.

  2. #2
    Membre confirmé
    Homme Profil pro
    Étudiant
    Inscrit en
    Novembre 2010
    Messages
    254
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2010
    Messages : 254
    Points : 538
    Points
    538
    Par défaut
    pl est un pointeur vers le premier élément de ta liste.
    "L'insanité consiste à répéter la même action dans l'espoir d'aboutir à un résultat différent" Albert Einstein
    ----------------------
    T.O.A.O 6-MarViN

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Novembre 2010
    Messages
    71
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2010
    Messages : 71
    Points : 49
    Points
    49
    Par défaut
    Mais pourquoi ?
    Et si c'est le cas, le fait de faire :
    Ne va pas supprimer ce premier élément ?

  4. #4
    Expert éminent sénior
    Avatar de diogene
    Homme Profil pro
    Enseignant Chercheur
    Inscrit en
    Juin 2005
    Messages
    5 761
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Enseignant Chercheur
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 761
    Points : 13 926
    Points
    13 926
    Par défaut
    Citation Envoyé par 6-MarViN Voir le message
    pl est un pointeur vers le premier élément de ta liste.
    Non, pl est l'adresse du pointeur sur le premier élément de la liste.
    La confusion vient de ce pointeur caché dans la définition de LISTE.
    Pour la clarté, il est préférable d'écrire
    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
    typedef struct maillon
    {
    	int info;
    	struct maillon * suivant;
    } MAILLON;
     
    typedef struct   // ce qui peut permettre d'ajouter d'autres informations
    {                // (pointeur de queue, nombre d'éléments,...)
       MAILLON * tete;
    }LISTE;
     
    void insert_tete(LISTE *pL, int n)
    {
         MAILLON * L = malloc(sizeof *L);
         if(L!= NULL)
         {
             L->info = n;
             L->suivant = pL->tete;
             pL->tete = L;
         }
    } 
    ...
    LISTE liste ={NULL};
    insert_tete(&liste, n);
    Publication : Concepts en C

    Mon avatar : Glenn Gould

    --------------------------------------------------------------------------
    Une réponse vous a été utile ? Remerciez son auteur en cliquant le pouce vert !

  5. #5
    Membre chevronné
    Profil pro
    Inscrit en
    Août 2006
    Messages
    1 104
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 1 104
    Points : 1 750
    Points
    1 750
    Par défaut
    Ne va pas supprimer ce premier élément ?
    Non, ce premier élément devient simplement le second.
    Le fait de modifier un pointeur (qui a comme valeur le retour de malloc) ne libère pas la mémoire allouée. Ici, ce pointeur n'est pas perdu, il est juste copié dans le membre "suivant" de l'objet structure, qui, juste après, devient le premier élément de la chaîne.

Discussions similaires

  1. Les listes chaînées
    Par AureK dans le forum GTK+ avec C & C++
    Réponses: 6
    Dernier message: 05/09/2007, 17h52
  2. Les listes chaînées
    Par dyala dans le forum Langage
    Réponses: 2
    Dernier message: 22/05/2007, 10h09
  3. petit problème sur les listes chaînées
    Par poche dans le forum C
    Réponses: 14
    Dernier message: 19/03/2007, 16h53
  4. [TP 7] Problème avec les listes chaînées (error 202)
    Par thelinekioubeur dans le forum Turbo Pascal
    Réponses: 4
    Dernier message: 06/12/2006, 23h15
  5. Réponses: 7
    Dernier message: 22/10/2005, 19h20

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