AGB  ·  Datenschutz  ·  Impressum  







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

Erklärung zum Sortieralgorithmus

Ein Thema von Dummfisch · begonnen am 15. Jan 2006 · letzter Beitrag vom 15. Jan 2006
Antwort Antwort
Dummfisch

Registriert seit: 21. Aug 2004
Ort: Dresden
8 Beiträge
 
#1

Erklärung zum Sortieralgorithmus

  Alt 15. Jan 2006, 17:58
Hey,

ich habe eine Frage zu folgendem Sortieralgorithmus:

Delphi-Quellcode:
procedure tausch (var a, b : integer);
var
  h: integer;
begin
  h := a;
  a := b;
  b := h;
end;


procedure sortieren (var feld : TFeld);
var
  i, y : integer;
begin

for i := 1 to 5 do
  begin
    y := i;
    while feld[y+1] < feld[y] do
    begin
      tausch (feld[y], feld[y+1]);
      if y > 1 then dec(y);
  end;
end;

end;
Was genau macht das if y > 1 then dec(y) ?
Also ich weiß, dass da der Wert y um 1 vermindert wird, wenn y > 1 ist, aber warum wird das gemacht?
y ist doch immer i und innerhalb der While-Schleife wird doch der Wert nicht geändert?
Kann mir das jemand näher erklären wie das funktioniert? Ich denke das hängt irgendwie mit dem Sortieralgorithmus zusammen oder?

Danke schonmal!

MfG
  Mit Zitat antworten Zitat
marabu

Registriert seit: 6. Apr 2005
10.109 Beiträge
 
#2

Re: Erklärung zum Sortieralgorithmus

  Alt 15. Jan 2006, 18:11
Hallo.

Dein Code implementiert den BubbleSort Algorithmus. Dabei werden die Einträge eines Vektors immer paarweise verglichen. Wenn die Ordnung gestört ist (bei dir wird aufsteigend sortiert) dann wird getauscht. Während die äußere Schleife vom kleinsten bis zum zweitgrößten Index des Vektors läuft, läuft die innere Schleife genau soweit wie nötig wieder zurück, um die zu kleinen Zahlen durch paarweises Tauschen an ihren vorläufigen Platz verschieben zu können. Wenn die äußere Schleife beendet wird, ist dein Vektor korrekt sortiert.

Grüße vom marabu
  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 16:23 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