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 chainées


Sujet :

C

  1. #1
    Nouveau membre du Club
    Inscrit en
    Janvier 2008
    Messages
    47
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 47
    Points : 32
    Points
    32
    Par défaut Les listes chainées
    cet exemple concerne lla modelisation des piles par les listes chainee
    qui peut m'aider a comprendre les mots qui ont en rouge ,s'il vous plait je veux une explication:

    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
    #include<stdio.h>
    #include<stdlib.h>
    struct liste
    {
    int valeur;
    struct liste*suivant;
    };
    main()
    {
    struct liste *l, *precedent,*nouveau;
    l=(struct liste *)malloc(sizeof(struct liste));
    printf("donner un entier positif");
    scanf("%d",&l->valeur);
    precedent=l;
    while(precedent->valeur!=0)
    {
    nouveau=(struct liste*)malloc(sizeof(struct liste));
    precedent->suivant=nouveau;
    precedent=nouveau;
    printf("donner un entier positif");
    scanf("%d",&precedent->valeur);
    }
    precedent->suivant=NULL;
    while(l!=NULL)
    {
    printf("%d",l->valeur);
    l=l->suivant;
    }
    }

  2. #2
    Membre régulier
    Profil pro
    Étudiant
    Inscrit en
    Août 2007
    Messages
    168
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Août 2007
    Messages : 168
    Points : 82
    Points
    82
    Par défaut
    c'est un programme de création d'une liste puis l'afficher !!!

    peux tu préciser un peu ton probleme !

  3. #3
    Nouveau membre du Club
    Inscrit en
    Janvier 2008
    Messages
    47
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 47
    Points : 32
    Points
    32
    Par défaut
    je veux savoir qui est le role des mots ecrits en rouge

  4. #4
    Membre régulier
    Profil pro
    Étudiant
    Inscrit en
    Août 2007
    Messages
    168
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Août 2007
    Messages : 168
    Points : 82
    Points
    82
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    struct liste
    {
    int valeur;
    struct liste*suivant;
    un champ suivant qui est un pointeur pointe sur un élément de la liste

    "l" c'est le pointeur qui pointe sur la tete de la liste , precedent pointe sur le dernier element de la liste pour qu'on peux lier ce dernier par le nouveaux element qu'on alloue
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    l=(struct liste *)malloc(sizeof(struct liste));
    en alloue le premier element
    le pointeur precedente pointe sur le tete aussi
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    while(precedent->valeur!=0)
    tantque l'utilisateur n'a pas entrer la valeur 0
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    nouveau=(struct liste*)malloc(sizeof(struct liste));
    en alloue le nouveau element
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    precedent->suivant=nouveau;
    le pointeur precedent contient un champs qui a le nom "suivant" alors ce pointeur (suivant) pointe sur le nouveau element , c'est ça le chainnage !!

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    precedent->suivant=NULL;
    si l'utilisateur a entrer "0" on sort de la boucle est bien sur maintenant le suivant du pointeur precedent prend la valeur NULL car on va pas le lier avec un autre element !!

    à chaque itération le pointeur serait pointer sur l'element suivant pour afficher sa valeur !!

  5. #5
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 369
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    J'ai renommé les variables et déplacé leurs déclarations afin d'avoir un code plus compréhensible:
    Code C : 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
    #include<stdio.h>
    #include<stdlib.h>
     
    struct liste
    {
    	int valeur;
    	struct liste *pSuivant;
    };
     
    int main(void)
    {
    	struct liste *pPremier;
     
    	pPremier = malloc(sizeof *pPremier));
    	if(pPremier != NULL)
    	{
    		struct liste *pDernier;
     
    		printf("donner un entier positif");
    		scanf("%d", &pPremier->valeur);
    		pDernier = pPremier;
    		while(pDernier->valeur!=0)
    		{
    			struct liste *pNouveau;
    			pNouveau = malloc(sizeof *pNouveau);
    			if(pNouveau == NULL)
    				break;
    			pDernier->pSuivant = pNouveau;
    			pDernier = pNouveau;
    			printf("donner un entier positif");
    			scanf("%d", &pDernier->valeur);
    		}
    		pDernier->pSuivant=NULL;
     
    		/* Affichage */
    		{
    			struct list * pCourant = pPremier;
    			while(pCourant!=NULL)
    			{
    				printf("%d", pCourant->valeur);
    				pCourant = pCourant ->suivant;
    			}
    		}
    	}
    	return 0;
    }
    Il reste encore à rendre pCourant const puisqu'il ne modifie pas la liste, et à effacer la liste avec une troisième boucle.
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  6. #6
    Nouveau membre du Club
    Inscrit en
    Janvier 2008
    Messages
    47
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 47
    Points : 32
    Points
    32
    Par défaut Structures de données
    bonjour mes amis j"ai un prgm de liste chainne le suivant :
    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
     
    #include<stdio.h>
    #include<stdlib.h>
     
    struct liste
    {
        int valeur;
        struct liste*suivant;
    };
     
    main()
    {
        struct liste *l, *precedent,*nouveau;
     
        l=(struct liste *)malloc(sizeof(struct liste));
     
        printf("donner un entier positif");
        scanf("%d",&l->valeur);
        precedent=l;
     
        while(precedent->valeur!=0)
        {
            nouveau=(struct liste*)malloc(sizeof(struct liste));
            precedent->suivant=nouveau;
            precedent=nouveau;
            printf("donner un entier positif");
            scanf("%d",&precedent->valeur);
        }
     
        precedent->suivant=NULL;
     
        while(l!=NULL)
        {
            printf("%d",l->valeur);
            l=l->suivant;
        }
    }
    mais j'ai pas compris la ligne d'affichage :printf("%d",l->valeur);
    je ce que je sais c'est que "l" un pointeur il pointe sur la premiere valeur de la liste mais cmt il egal a 0,si vous un cours avec execrcice de stucture des donnes en c ,donnez moi ce cours please

  7. #7
    Nouveau membre du Club
    Inscrit en
    Janvier 2008
    Messages
    47
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 47
    Points : 32
    Points
    32
    Par défaut
    excusez moi j'ai pas compris ca :while(l!=NULL)

  8. #8
    Membre émérite Avatar de nicolas.sitbon
    Profil pro
    Inscrit en
    Août 2007
    Messages
    2 015
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 2 015
    Points : 2 280
    Points
    2 280
    "The quieter you become, the more you are able to hear"
    "Plus vous êtes silencieux, plus vous êtes capable d'entendre"

  9. #9
    Membre actif
    Homme Profil pro
    Inscrit en
    Octobre 2007
    Messages
    487
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2007
    Messages : 487
    Points : 294
    Points
    294
    Par défaut
    Citation Envoyé par youssef222 Voir le message
    bonjour mes amis j"ai un prgm de liste chainne le suivant :
    #include<stdio.h>
    #include<stdlib.h>
    struct liste
    {
    int valeur;
    struct liste*suivant;
    };
    main()
    {
    struct liste *l, *precedent,*nouveau;
    l=(struct liste *)malloc(sizeof(struct liste));
    printf("donner un entier positif");
    scanf("%d",&l->valeur);
    precedent=l;
    while(precedent->valeur!=0)
    {
    nouveau=(struct liste*)malloc(sizeof(struct liste));
    precedent->suivant=nouveau;
    precedent=nouveau;
    printf("donner un entier positif");
    scanf("%d",&precedent->valeur);
    }
    precedent->suivant=NULL;
    while(l!=NULL)
    {
    printf("%d",l->valeur);
    l=l->suivant;
    }
    }
    mais j'ai pas compris la ligne d'affichage :printf("%d",l->valeur);
    je ce que je sais c'est que "l" un pointeur il pointe sur la premiere valeur de la liste mais cmt il egal a 0,si vous un cours avec execrcice de stucture des donnes en c ,donnez moi ce cours please

    L c’est la tête que tu as créé
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    l=(struct liste *)malloc(sizeof(struct liste));
    printf("donner un entier positif");
    scanf("%d",&l->valeur);
    precedent=l;
    puis tu as remplit ta liste avec cette boucle
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    while(precedent->valeur!=0)
    {
    nouveau=(struct liste*)malloc(sizeof(struct liste));
    precedent->suivant=nouveau;
    precedent=nouveau;
    printf("donner un entier positif");
    scanf("%d",&precedent->valeur);
    }
    precedent->suivant=NULL;
    après l c’est la tête de ta liste
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    while(l!=NULL)
    {
    printf("%d",l->valeur);
    l=l->suivant;
    }
    Tantque la tête n’a pas arrive a la fin ça veut dire NULL tu affiche puis tu te déplace vers l’élément qui suit

  10. #10
    Nouveau membre du Club
    Inscrit en
    Janvier 2008
    Messages
    47
    Détails du profil
    Informations forums :
    Inscription : Janvier 2008
    Messages : 47
    Points : 32
    Points
    32
    Par défaut d'ajout d'un element a liste chainné
    --------------------------------------------------------------------------------

    bonjour mes amis j'ai besoin de votre aide svp:ca le prgm d'ajout d'un element a liste chainné,j'ai pas compris le role de mots qui ont ecrits en rouge :
    la fonction ajout
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    struct liste *ajout(int val,struct liste *p)
    {
    struct liste *q,*nouveau;
    q=p;
    while(q=q->suivant!=NULL)
    q=q->suivant;

  11. #11
    Membre régulier
    Profil pro
    Étudiant
    Inscrit en
    Août 2007
    Messages
    168
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Août 2007
    Messages : 168
    Points : 82
    Points
    82
    Par défaut
    Citation Envoyé par youssef222 Voir le message
    bonjour mes amis j'ai besoin de votre aide svp:ca le prgm d'ajout d'un element a liste chainné,j'ai pas compris le role de mots qui ont ecrits en rouge :
    la fonction ajout
    struct liste *ajout(int val,struct liste *p)
    {
    struct liste *q,*nouveau;
    q=p;
    while(q=q->suivant!=NULL)
    q=q->suivant;

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    struct liste *ajout(int val,struct liste *p)
    struct liste *p : p est un pointeur sur un element de type : struct liste, c'est à dire qu'on envois à la fonction ajout la valeur à ajouter "int val" , et aussi le pointeur qui pointe sur le 1er element de la liste .
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    {
    struct liste *q,*nouveau;
    ici on déclare que q,nouveau sont 2 pointeur sur un element de type "struct liste".
    ici q prends la meme valeur de p , c'est à dire que si p pointe sur un element "X" , q va pointer aussi sur cet element .


    je te conseille de voir des documents sur les listes , ce site est plein du ce genre de documents !!!

Discussions similaires

  1. les listes chaines en c++ builder
    Par touf213 dans le forum C++Builder
    Réponses: 2
    Dernier message: 01/07/2007, 18h06
  2. Toujours les listes chainées
    Par KindPlayer dans le forum C
    Réponses: 2
    Dernier message: 26/02/2007, 10h00
  3. des questions sur les listes chainées
    Par hunter99 dans le forum C
    Réponses: 13
    Dernier message: 05/12/2006, 22h51
  4. les listes chaineés(structures)
    Par snakemetalgear dans le forum C
    Réponses: 18
    Dernier message: 14/11/2006, 18h09
  5. les listes chainées
    Par najwWa dans le forum Algorithmes et structures de données
    Réponses: 4
    Dernier message: 22/03/2006, 19h09

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