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

Turbo Pascal Discussion :

Suppression d'éléments d'une liste chaînée simple


Sujet :

Turbo Pascal

  1. #1
    Membre habitué
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2010
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2010
    Messages : 8
    Par défaut Suppression d'éléments d'une liste chaînée simple
    Bonjour à tous;

    Voilà j'ai un problème, je veux faire un algo qui supprime toutes les valeurs négatives d'une liste chaînée (simple) donnée; mon problème exact c'est comment on supprime deux valeurs négatives l'une après l'autre (Turbo Pascal).

    Merci d'avance.

  2. #2
    Membre chevronné
    Avatar de richard
    Homme Profil pro
    Inscrit en
    Avril 2002
    Messages
    475
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Puy de Dôme (Auvergne)

    Informations forums :
    Inscription : Avril 2002
    Messages : 475
    Par défaut
    La suppression d'un élément dans une liste chaînée se résume grosso modo à une redirection de pointeurs. Quand on sait supprimer un élément d'une telle liste, pour supprimer deux éléments ... il suffit de faire la même chose une fois de plus.

    Un bout de code ?

  3. #3
    Membre habitué
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2010
    Messages
    8
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2010
    Messages : 8
    Par défaut
    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
    program liste;
     
    type
      lien =^objet;
      objet=record
          	  info :real;
    	  suivant: lien;
            end;
     
    var
      sommet, p, q : lien;
      i : integer;
     
    begin
      write('entrer 6 nombre : ');
      sommet := Nil;
      for i := 1 to 6 do
        begin
          New(p); read(p^.info);
          p^.suivant:=sommet;
          sommet:=p;
        end;
     
      while  p <> nil do
        begin
          if (p^.info < 0) then
            begin
              q := p;
              p := p^.suivant;
              q^.suivant := p;
              dispose(q);
            end;
          if p^.info > 0 then
            begin
              write(p^.info);
              p:=p^.suivant;
            end;
        end;
    end.

  4. #4
    Responsable Pascal, Lazarus et Assembleur


    Avatar de Alcatîz
    Homme Profil pro
    Ressources humaines
    Inscrit en
    Mars 2003
    Messages
    8 055
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ressources humaines
    Secteur : Service public

    Informations forums :
    Inscription : Mars 2003
    Messages : 8 055
    Billets dans le blog
    2
    Par défaut
    Bonjour,

    Le problème est qu'au moment de la détection de l'élément négatif, tu as perdu l'adresse de l'élément qui lui précède.

    Tu peux peut-être utiliser la variable q pour conserver cette adresse :
    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
      q := p;
      while  p <> nil do
        begin
          if (p^.info < 0) then
            begin
              q^.suivant := p^.suivant;
              dispose(p);
              p := q;
            end;
          if p^.info > 0 then
            begin
              write(p^.info);
              p := p^.suivant;
            end;
          q := p;
          p := p^.suivant;
        end;
    J'ai rapidement testé sur papier mais il faut regarder si c'est valide avec un élément négatif en début de liste ou en fin de liste, ou si tous les éléments de la liste sont négatifs.
    Règles du forum
    Cours et tutoriels Pascal, Delphi, Lazarus et Assembleur
    Avant de poser une question, consultez les FAQ Pascal, Delphi, Lazarus et Assembleur
    Mes tutoriels et sources Pascal

    Le problème en ce bas monde est que les imbéciles sont sûrs d'eux et fiers comme des coqs de basse cour, alors que les gens intelligents sont emplis de doute. [Bertrand Russell]
    La tolérance atteindra un tel niveau que les personnes intelligentes seront interdites de toute réflexion afin de ne pas offenser les imbéciles. [Fiodor Mikhaïlovitch Dostoïevski]

  5. #5
    Expert confirmé

    Inscrit en
    Août 2006
    Messages
    3 969
    Détails du profil
    Informations forums :
    Inscription : Août 2006
    Messages : 3 969
    Par défaut
    Fao,

    Certains diront que je me répète, mais ce genre de problème est typiquement de ceux qu'on résout avec

    papier + crayon



Discussions similaires

  1. [TPW] Erreur lors de l'ajout d'un élément dans une liste chaînée triée
    Par sangimed dans le forum Turbo Pascal
    Réponses: 5
    Dernier message: 18/01/2013, 21h37
  2. [Free Pascal] Insertion d'éléments dans une liste chaînée
    Par Pacorabanix dans le forum Free Pascal
    Réponses: 4
    Dernier message: 20/04/2010, 00h42
  3. Réponses: 2
    Dernier message: 18/04/2010, 11h15
  4. Suppression d' éléments dans une liste.
    Par conan76 dans le forum ASP.NET
    Réponses: 3
    Dernier message: 02/03/2007, 09h33
  5. Récupérer le Nième élément d'une liste chaînée
    Par decoy Octopus dans le forum Pascal
    Réponses: 3
    Dernier message: 03/11/2006, 18h03

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