AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Sortieren einer Liste?

Ein Thema von Chris P · begonnen am 13. Apr 2004 · letzter Beitrag vom 13. Apr 2004
Antwort Antwort
Chris P

Registriert seit: 8. Mär 2004
230 Beiträge
 
Delphi 7 Enterprise
 
#1

Sortieren einer Liste?

  Alt 13. Apr 2004, 21:37
Hi Leute, ich will eine einfach verkettete Liste nach Namen sortieren.
Aber wo liegt der Fehler???

Delphi-Quellcode:
procedure TForm1.SortList();
var
   Nav, Help: PZeiger;
begin
   Nav := Root;

   while Nav^.Next <> nil do
   begin
      if Nav^.Name > Nav^.Next^.Name then
      begin
         Help := Nav;
         Nav := Nav^.Next;
         Nav^.Next := Help;
      end;
   Nav := Nav^.Next;
   end;
end;
Die Liste ist später durcheinander.

Kann mir jemand helfen?

Danke...
  Mit Zitat antworten Zitat
xineohp

Registriert seit: 29. Jan 2004
Ort: Heusenstamm
420 Beiträge
 
Delphi 2005 Professional
 
#2

Re: Sortieren einer Liste?

  Alt 13. Apr 2004, 21:44
der Sortieralgorithmus ist unvollständig. Wenn mich nicht alles täuscht fehlt die zweite Schleife.

phoenix
Peter Enenkel
  Mit Zitat antworten Zitat
Chris P

Registriert seit: 8. Mär 2004
230 Beiträge
 
Delphi 7 Enterprise
 
#3

Re: Sortieren einer Liste?

  Alt 13. Apr 2004, 21:46
Zweite Schleife??? Soweit ich mich erinnere geht es auch mit einer.

Könntest du mir helfen?
  Mit Zitat antworten Zitat
xineohp

Registriert seit: 29. Jan 2004
Ort: Heusenstamm
420 Beiträge
 
Delphi 2005 Professional
 
#4

Re: Sortieren einer Liste?

  Alt 13. Apr 2004, 21:53
Delphi-Quellcode:
procedure TForm1.SortList();
var
   Nav, Help: PZeiger;
   veraendert: boolean;
begin

   repeat
   veraendert := false;

   Nav := Root;
   while Nav^.Next <> nil do
   begin
      if Nav^.Name > Nav^.Next^.Name then
      begin
         Help := Nav;
         Nav := Nav^.Next;
         Nav^.Next := Help;
         veraendert := true;
      end;
   Nav := Nav^.Next;
   end;
   
   until not veraendert;

end;
so müsste es funktionieren. Nennt sich Bubblesort.
siehe auch: delphi-source

phoenix
Peter Enenkel
  Mit Zitat antworten Zitat
Chris P

Registriert seit: 8. Mär 2004
230 Beiträge
 
Delphi 7 Enterprise
 
#5

Re: Sortieren einer Liste?

  Alt 13. Apr 2004, 21:56
Das sieht schon ma gut aus!

Werds ma probieren, ich danke dir!
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 05:59 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz