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 :

probleme d affichage une liste chainee


Sujet :

C

  1. #1
    Nouveau Candidat au Club
    Inscrit en
    Avril 2005
    Messages
    3
    Détails du profil
    Informations forums :
    Inscription : Avril 2005
    Messages : 3
    Points : 1
    Points
    1
    Par défaut probleme d affichage une liste chainee
    salut

    j ai un probleme lors d affichage d une liste chaine. le probleme lors d inserer les valeur par exemple j insere 5 et 7 et 8 dans l affichage je trouve 8 8 8
    la valeur 8 se repete 3 fois :

    voici mon script d affichage liste chainée :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    void affichage(liste *adl)
    {
       Tnoeud *p ;
       p=adl->debut ;
       do
       {
          printf("%d",x);
          p=p->suiv ;
       }
       while((p->suiv)!=NULL);
    }
    s il y a quelqu un peut corriger la procedure affichage .

    merci d avance

  2. #2
    Membre Expert

    Homme Profil pro
    Ingénieur R&D
    Inscrit en
    Juin 2003
    Messages
    4 506
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2003
    Messages : 4 506
    Points : 5 724
    Points
    5 724
    Par défaut
    p->suivant il est initialiser quand ?
    " Dis ce que tu veux qui insulte mon honneur car mon silence sera la réponse au mesquin.
    Je ne manque pas de réponse mais : il ne convient pas aux lions de répondre aux chiens ! " [Ash-Shafi'i ]

  3. #3
    Nouveau Candidat au Club
    Inscrit en
    Avril 2005
    Messages
    3
    Détails du profil
    Informations forums :
    Inscription : Avril 2005
    Messages : 3
    Points : 1
    Points
    1
    Par défaut
    mais je n ai pas initialise p->suivant mais ou je vais le initialiser ?

  4. #4
    Membre averti Avatar de Jack_serious
    Profil pro
    Inscrit en
    Septembre 2005
    Messages
    350
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Septembre 2005
    Messages : 350
    Points : 396
    Points
    396
    Par défaut


    Citation Envoyé par lhagame
    do
    {
    printf("%d",x);
    p=p->suiv ;
    }
    while((p->suiv)!=NULL);
    C'est quoi ce 'x' ?
    Ne devrait-ce pas plutot etre p->data ou quelque chose du genre ?

    Sinon pourrait-on voir comment tu remplis ta liste chainee ?
    Don't worry, be serious.
    La vie est courte. Prenez votre temps.

    Jack.

  5. #5
    Nouveau Candidat au Club
    Inscrit en
    Avril 2005
    Messages
    3
    Détails du profil
    Informations forums :
    Inscription : Avril 2005
    Messages : 3
    Points : 1
    Points
    1
    Par défaut
    voici mon programme :

    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
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    #include <conio.h>
    #include <stdio.h>
    #include <stdlib.h>
    typedef struct tnoeud 
    {
       int ele ;
       struct  tnoeud *suiv ;
    } Tnoeud ;
     
    typedef struct 
    {
       Tnoeud *debut ;
       Tnoeud *fin ;
       int     lg ;
    }liste ;
     
    liste *adl ;
    int n,i,x,lg;
    char rep ;
     
    /*creer un noeud */
    Tnoeud * creer_noeud (int x)
    {
       Tnoeud *p ;
     
       p= (Tnoeud * )malloc (sizeof(Tnoeud));
     
       if (p)
       {
          p->ele = x ;
          p->suiv = NULL ;
       }
       return p ;
    }
     
    void initialiser (liste *adl)
    {
       adl->debut=NULL ;
       adl->fin=NULL;
       adl->lg = 0 ;
    }
     
    void inserer ( liste *adl , int x )
    {
       Tnoeud *p = creer_noeud(x);
     
       if (p)
       {
          adl->debut = adl->fin = p ;
          adl->lg+=1;
       }
       else
       {
          adl->fin->suiv = p;
          adl->fin = p ;
          adl->lg+=1;
       }
     
       printf("la longeur est : %d \n",adl->lg);
    }
     
    void affichage(liste *adl)
    {
       Tnoeud *p ;
     
       p=adl->debut ;
       do
       {
          printf("%d",x);
          p=p->suiv ;
       }
       while((p->suiv)!=NULL);
    }
     
    void main ()
    {
       clrscr();
     
       /* apel fonction inserer*/
       initialiser(adl);
       do
       {
          printf("entrer une valeur : ");
          scanf("%d",&x);
          inserer(adl,x);
          printf("voulez vous inserer: ");
          scanf("%s",&rep);
       }
       while(rep=='o');
       /*affichage*/
       affichage(adl);
       getch();
    }

  6. #6
    Expert éminent sénior

    Avatar de fearyourself
    Homme Profil pro
    Ingénieur Informaticien Senior
    Inscrit en
    Décembre 2005
    Messages
    5 121
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : Etats-Unis

    Informations professionnelles :
    Activité : Ingénieur Informaticien Senior
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2005
    Messages : 5 121
    Points : 11 877
    Points
    11 877
    Par défaut
    J'ai corrigé le code,

    Citation Envoyé par lhagames
    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
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    #include <conio.h>
    #include <stdio.h>
    #include <stdlib.h>
    typedef struct tnoeud
    {
       int ele ;
       struct  tnoeud *suiv ;
    } Tnoeud ;
     
    typedef struct
    {
       Tnoeud *debut ;
       Tnoeud *fin ;
       int     lg ;
    }liste ;
     
    /* -fy- variable globale, c'est mal*/
     
    /*creer un noeud */
    Tnoeud * creer_noeud (int x)
    {
       Tnoeud *p ;
       /* -fy- On ne cast plus malloc */
       p= malloc (sizeof(Tnoeud));
     
       if (p)
       {
          p->ele = x ;
          p->suiv = NULL ;
       }
       return p ;
    }
     
    /* -fy- pas un bon prototype pour une fonction initialiser*/
    liste *initialiser ()
    {
       liste *adl = malloc(sizeof *adl);
       if(adl)
        {
        adl->debut=NULL ;
        adl->fin=NULL;
        adl->lg = 0 ;
       }
    return adl;
    }
     
    void inserer ( liste *adl , int x )
    {
       Tnoeud *p = creer_noeud(x);
     
       /*-fy- Je pense que c'est la liste que tu veux tester
       Si elle est vide alors p est le debut et la fin
       Mais d'abord on teste la valeur de p
      */
     
       if(p!=NULL)
       {
        if (adl->debut==NULL)
         {
          adl->debut = adl->fin = p ;
          adl->lg+=1;
         }
       else
         {
          adl->fin->suiv = p;
          adl->fin = p ;
          adl->lg+=1;
         }
      }
       printf("la longeur est : %d \n",adl->lg);
    }
     
    void affichage(liste *adl)
    {
       Tnoeud *p ;
     
       p=adl->debut ;
     
       /* -fy- Plutôt un while, p peut être tout de suite à NULL */
       while(p)
       {
          /*-fy- C'est peut-être p->x, non? */
          printf("%d",p->ele);
          p=p->suiv ;
       }
     
    }
     
    /* -fy- C'est int main */
    int main (void)
    {
       char tmp[128];
       long x;
       liste *adl;
     
       /* apel fonction inserer*/
       /* -fy- Ta fonction initialiser ne pouvait pas marcher comme cela */
       adl = initialiser();
       do
       {
          printf("entrer une valeur : ");
          /* -fy- On n'utilise plus scanf mais fgets*/
         fgets(tmp,sizeof tmp, stdin);
         x = strtol(tmp,NULL,0);
     
          inserer(adl,x);
          printf("voulez vous inserer: ");
     
          /*-fy- On n'utilise pas scanf et en plus celui là était faux...*/
          fgets(tmp,sizeof tmp,stdin);
       }
       while(!strcmp(tmp,"o\n"));
     
       /*affichage*/
       affichage(adl);
       getch();
       return 0;
    }
    Il faudrait réviser son C tout de même...

    Jc

  7. #7
    Membre expert
    Avatar de Pragmateek
    Homme Profil pro
    Formateur expert .Net/C#
    Inscrit en
    Mars 2006
    Messages
    2 635
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Formateur expert .Net/C#
    Secteur : Conseil

    Informations forums :
    Inscription : Mars 2006
    Messages : 2 635
    Points : 3 958
    Points
    3 958
    Par défaut
    Il manque Mais sinon ça à l'air parfait.

    Pourquoi la fonction initialiser(...) était invalide?
    Elle l'était c'est sûr mais pourquoi?

    Merci.
    Formateur expert .Net/C#/WPF/EF Certifié MCP disponible sur Paris, province et pays limitrophes (enseignement en français uniquement).
    Mon blog : pragmateek.com

  8. #8
    Rédacteur/Modérateur
    Avatar de Trap D
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    4 942
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2003
    Messages : 4 942
    Points : 6 498
    Points
    6 498
    Par défaut
    Citation Envoyé par seriousme
    Il manque Mais sinon ça à l'air parfait.

    Pourquoi la fonction initialiser(...) était invalide?
    Elle l'était c'est sûr mais pourquoi?

    Merci.
    Dans le premier code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    void initialiser (liste *adl)
    {
       adl->debut=NULL ;
       adl->fin=NULL;
       adl->lg = 0 ;
    }
    On ne voit aucune allocation de mémoire.
    Comme adl est un pointeur global, il est initialisé à 0, soit une valeur invalide et donc les adl->??? font planter joyeusement le programme.
    "La haine seule fait des choix" - Koan Zen
    "Il ne faut pas être meilleur que les autres, il faut être meilleur que soi." Albert Jacquard
    "Ceux qui savent où ils ont posé leur parapluie ne sont pas alcooliques." - pgibonne.
    Faites du Prolog, ça vous changera les idées !
    Ma page Prolog
    Mes codes sources commentés

    Mon avatar : La Madeleine à la veilleuse de Georges de La Tour

  9. #9
    Membre expert
    Avatar de Pragmateek
    Homme Profil pro
    Formateur expert .Net/C#
    Inscrit en
    Mars 2006
    Messages
    2 635
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Formateur expert .Net/C#
    Secteur : Conseil

    Informations forums :
    Inscription : Mars 2006
    Messages : 2 635
    Points : 3 958
    Points
    3 958
    Par défaut
    Heu sans changer la fonction initialiser est-ce que
    aurait suffit?

    De plus mon compilo me fait des miseres au niveau des malloc:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     p= malloc (sizeof(Tnoeud));
    ...
    liste *adl = malloc(sizeof *adl);
    Il me faut mettre :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     p=(Tnoeud *) malloc (sizeof(Tnoeud));
    ...
    liste *adl = (liste *)malloc(sizeof *adl);
    Au fait comment appelle t'on cette opération: (type)malloc(...)?
    Un tanstypage?
    Formateur expert .Net/C#/WPF/EF Certifié MCP disponible sur Paris, province et pays limitrophes (enseignement en français uniquement).
    Mon blog : pragmateek.com

  10. #10
    Rédacteur/Modérateur
    Avatar de Trap D
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    4 942
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2003
    Messages : 4 942
    Points : 6 498
    Points
    6 498
    Par défaut
    Tu fais du C ou du C++ ??
    Ton fichier doit avoir l'extension .c et non .C ou .cpp.
    Le compilo C ne doit pas râler sur
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    p= malloc (sizeof(Tnoeud));
    D'autre par si tu fais lors de l'intialisation, ça va forcement faire boum si tu gardes ta fonction de début.
    "La haine seule fait des choix" - Koan Zen
    "Il ne faut pas être meilleur que les autres, il faut être meilleur que soi." Albert Jacquard
    "Ceux qui savent où ils ont posé leur parapluie ne sont pas alcooliques." - pgibonne.
    Faites du Prolog, ça vous changera les idées !
    Ma page Prolog
    Mes codes sources commentés

    Mon avatar : La Madeleine à la veilleuse de Georges de La Tour

  11. #11
    Expert éminent sénior

    Avatar de fearyourself
    Homme Profil pro
    Ingénieur Informaticien Senior
    Inscrit en
    Décembre 2005
    Messages
    5 121
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : Etats-Unis

    Informations professionnelles :
    Activité : Ingénieur Informaticien Senior
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2005
    Messages : 5 121
    Points : 11 877
    Points
    11 877
    Par défaut
    Citation Envoyé par seriousme
    Heu sans changer la fonction initialiser est-ce que
    aurait suffit?

    De plus mon compilo me fait des miseres au niveau des malloc:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     p= malloc (sizeof(Tnoeud));
    ...
    liste *adl = malloc(sizeof *adl);
    Il me faut mettre :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     p=(Tnoeud *) malloc (sizeof(Tnoeud));
    ...
    liste *adl = (liste *)malloc(sizeof *adl);
    Au fait comment appelle t'on cette opération: (type)malloc(...)?
    Un tanstypage?
    Tu es en train d'utiliser un compilateur C++, c'est pour cela.

    Et oui, le terme français est transtypage.

    Jc

Discussions similaires

  1. Réponses: 2
    Dernier message: 07/04/2010, 22h36
  2. Réponses: 2
    Dernier message: 21/02/2007, 13h28
  3. [ddd]Affichage d'une liste chainée.
    Par granquet dans le forum Autres éditeurs
    Réponses: 6
    Dernier message: 01/12/2006, 06h58
  4. [LG]probleme d'ajout dans une liste chainée...
    Par misteryann dans le forum Langage
    Réponses: 5
    Dernier message: 08/03/2004, 20h28
  5. [LG]suppression dans une liste chainée
    Par mister_dsg dans le forum Langage
    Réponses: 9
    Dernier message: 16/12/2003, 21h20

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