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 :

supprimer les repetitions dans une liste chaînée


Sujet :

C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Février 2007
    Messages
    38
    Détails du profil
    Informations forums :
    Inscription : Février 2007
    Messages : 38
    Par défaut supprimer les repetitions dans une liste chaînée
    Bonjour
    je doit écrire une fonction qui supprime les répétitions dans une liste chainée

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
     
    typedef struct cel 
    {
      int val;
      struct cel * suivant;
    } liste;
     
    typedef liste* PListe ;
     
    int taille(PListe L);//return la taille de la liste
     
    Liste suprimer(PListe L, int k);// supprimer l element du rang k
    j ai écrit cette fonction mais ça marche pas
    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
     
     
    PListe supprimer_repe(PListe L)
     {
         PListe p=NULL,pc=NULL,  prec=NULL;
     int k=0,i;
       p = L ;
     
       while ( p != NULL )
         { k++;
             pc=p->suivant ; 
             prec = p ;
     
    for(i=k;k<taille(L);i++)
                {
     
                    if (pc->val == p->val)
    L=supprimer(L,i);
                    else
                         prec = pc ;
     
                    pc = pc->suivant ;
                }                
     
             p=p->suivant; 
        }
     
    return L;
    }
    SVp aider moi

  2. #2
    Expert éminent
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 68
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Par défaut
    Citation Envoyé par Layla
    je doit écrire une fonction qui supprime les répétitions dans une liste chainée
    SVp aider moi
    C'est un problème d'algorithme. Je conseille de créer une deuxième liste temporaire.

    Et de déplacer les éléments de la première liste dans le 2ème, en vérifiant avant que l'élément n'y est pas. Quand c'est termine (liste initiale vide), la liste devient la nouvelle.
    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
     
    liste_s liste
     
    initaliser (liste)
     
    liste_s temp
     
    Pour chaque élément de liste : 
     element := retirer (liste)
     SI est_absent(temp, element)
      ajouter (temp, element)
     SINON
      liberer(element)
     FIN SI
     
    liste := temp

  3. #3
    Rédacteur
    Avatar de Franck.H
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Janvier 2004
    Messages
    6 951
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Haut Rhin (Alsace)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Service public

    Informations forums :
    Inscription : Janvier 2004
    Messages : 6 951
    Par défaut
    Ceci ne me semble pas correcte:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    for (i = k; k < taille (L); i++)
    La valeur de k change vu que c'est le début de ta boucle mais dans le parcours de ta liste jusqu'à atteindre la valeur retournée par:
    Tu peux avoir des surprises car là à chaque fois que tu supprime un noeud la taille change. J'aurais fait simplement une seconde boucle while comme la première.


    PS: il faudrait faire un effort de présentation du code...
    Mon Site
    Ma bibliothèque de gestion des chaînes de caractères en C

    L'imagination est plus importante que le savoir. A. Einstein

    Je ne répond à aucune question technique par MP, merci d'avance !

  4. #4
    Membre averti
    Inscrit en
    Février 2007
    Messages
    38
    Détails du profil
    Informations forums :
    Inscription : Février 2007
    Messages : 38
    Par défaut
    Citation Envoyé par Franck.H
    Ceci ne me semble pas correcte:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    for (i = k; k < taille (L); i++)
    oui oui c'est
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    for (i = k; i < taille (L); i++)
    Mais toujours ca marche pas

  5. #5
    Membre confirmé
    Inscrit en
    Avril 2007
    Messages
    31
    Détails du profil
    Informations personnelles :
    Âge : 57

    Informations forums :
    Inscription : Avril 2007
    Messages : 31
    Par défaut Demande de clarification
    Citation Envoyé par Layla
    Bonjour

    Je dois écrire une fonction qui supprime les répétitions dans une liste chainée .
    Bonjour,

    Cette fonction doit elle modifier la liste passee en parametre ou construire une nouvelle liste dont les elements sont ceux de la liste passee en parametre, sans repetition?

    Si la premiere interpretation est la bonne, il faudrait plutot considerer le prototype suivant:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    void supprimer_repe(Pliste * L);
    David.
    --

  6. #6
    Membre averti
    Inscrit en
    Février 2007
    Messages
    38
    Détails du profil
    Informations forums :
    Inscription : Février 2007
    Messages : 38
    Par défaut
    La fonction va biensur changer la liste passer en argument c pour ça elle doit retourné le debut

  7. #7
    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
    Par défaut
    C'est un petit tant que
    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
    void supprimer_repe(PListe L)
     {
     
       PListe p;
     
       while (p != NULL )
       { 
    	p->suivant = retirer(p->val, p->suivant);
            p  = p->suivant;
       }
    }
     
    PListe retirer(int val, PListe l)
    {
       PListe p = L;
     
       // traitement special de debut
       // on supprime les éléments de tête 
       // si leur valeur est val
       while(p!= NULL && p->val == val)
       {
         PListe tmp = p;
         p = p->suivant;
         free(tmp);
       }
       l = p;  
       // ici on est assuré, soit d'avoir un noeud NULL,
       // soit que p->val != val
       while(p != NULL && p->suivant != NULL)
       {
           if (p->suivant->val == val)
           {
              PListe tmp = p->suivant;
              p->suivant = tmp->suivant;
              free(tmp);
           }
       }
       return l;
    }
    Cette fonction ne peut pas changer le premier noeud de la liste donc il est inutile de renvoyer une nouvelle tête de liste.
    "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

Discussions similaires

  1. Supprimer les doublons dans une liste
    Par inforum dans le forum SL & STL
    Réponses: 2
    Dernier message: 22/11/2009, 15h21
  2. Supprimer les espaces dans une chaîne
    Par karaz_karaz dans le forum x86 16-bits
    Réponses: 3
    Dernier message: 28/05/2008, 16h27
  3. Supprimer les accents dans une chaîne
    Par SuperChafouin dans le forum Langage
    Réponses: 4
    Dernier message: 17/12/2007, 17h28
  4. [XPATH] supprimer les espaces dans une chaîne
    Par joeyd dans le forum XSL/XSLT/XPATH
    Réponses: 14
    Dernier message: 17/10/2007, 15h56
  5. supprimer les espaces dans une chaîne de caratères.
    Par Empty_body dans le forum Langage
    Réponses: 2
    Dernier message: 12/09/2006, 18h43

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