![]() |
Auswahlsort
Sers Leute,
bin gerade dabei Auswahlsort zu "programmieren". Es sollen Balken angeordnet werden unzwar vom kleinsten oben bis zum größten unten. Nur klappt es überhaupt nicht obwohl ich die ganze Zeit denke, dass der Code richtig ist. Vielleicht könnt Ihr mir sagen was an dem Code nicht stimmt? So werden die Balken gezeichnet, die dann zu sortieren sind ...
Delphi-Quellcode:
So werden die Balken sortiert ...
procedure TForm1.Button6Click(Sender: TObject);
begin PaintBox3.Repaint; index := BalkenZahl; yps := 1; For i := 1 To BalkenZahl Do Begin Application.Processmessages; PaintBox3.Canvas.Pen.Color := CLBlue; PaintBox3.Canvas.Rectangle(1, yps, index, yps+1); sleep(TrackBar1.Position); recsize2[index] := index; x2[index] := 1; y2[index] := yps; index := index-1; yps := yps+2; End; end;
Delphi-Quellcode:
procedure TForm1.Button8Click(Sender: TObject);
Var min : integer; begin Start := GetTickCount; tausch2 := 0; For i := 1 To BalkenZahl - 1 Do Begin min := recsize2[i]; Application.Processmessages; For j := i + 1 To BalkenZahl Do Begin Application.Processmessages; If recsize2[min] < recsize2[j] Then Begin min := j; End; End; If recsize2[min] <> recsize2[i] Then Begin PaintBox3.Canvas.Pen.Color := CLRed; PaintBox3.Canvas.Rectangle(1, y2[i], recsize2[i], y2[i]+1); PaintBox3.Canvas.Pen.Color := CLRed; PaintBox3.Canvas.Rectangle(1, y2[min], recsize2[min], y2[min]+1); sleep(TrackBar1.Position); PaintBox3.Canvas.Pen.Color := ClBtnFace; PaintBox3.Canvas.Rectangle(1, y2[i], recsize2[i], y2[i]+1); PaintBox3.Canvas.Pen.Color := ClBtnFace; PaintBox3.Canvas.Rectangle(1, y2[min], recsize2[min], y2[min]+1); temp2 := recsize2[i]; recsize2[i] := recsize2[min]; recsize2[min] := temp2; tausch2 := tausch2 + 1; PaintBox3.Canvas.Pen.Color := CLBlue; PaintBox3.Canvas.Rectangle(1, y2[i], recsize2[i], y2[i]+1); PaintBox3.Canvas.Pen.Color := CLBlue; PaintBox3.Canvas.Rectangle(1, y2[min], recsize2[min], y2[min]+1); sleep(TrackBar1.Position); Edit5.Text := IntToStr(tausch2); End; End; Edit7.Text := IntToStr(GetTickCount - Start); end; |
Re: Auswahlsort
Moin,
schonmal was von Einrücken gehört? Soll nicht bös gemeint sein, wäre aber etwas hilfreicher beim Lesen! wenn ich das richtig verstehe, sortierst du das Array recsize2 ? dann macht die Zeile
Delphi-Quellcode:
irgendwie wenig Sinn :gruebel:
recsize2[index]:=index
Grüße Minz OK es sei denn du willst das ganze nur umdrehen ! was genau funktioniert nicht, bzw. was macht er denn? |
Re: Auswahlsort
Zitat:
Delphi-Quellcode:
macht sehr viel Sinn, dort wird dem Element mit der Nummer index aus einem Array die Länge index zugeordnen. Also zum Beispiel recsize2[150] := 150.
recsize2[index]:=index
|
Re: Auswahlsort
siehe Edit oben
|
Re: Auswahlsort
Das Programm soll die Balken vom kleinsten oben bis zum größten unten sortieren (gezeichnet werden sie vom kleinsten unten bis zum größten oben).
Nur läuft er das ganze einmal durch und sortiert die Balken richtig und dann scheint er die Balken wieder in die Reihenfolge von vorhin zu bringen. Ich verstehe nicht warum? |
Re: Auswahlsort
Delphi-Quellcode:
Willst du da das Minimum oder das Maximum ermitteln?
For i := 1 To BalkenZahl - 1 Do Begin
min := recsize2[i]; Application.Processmessages; For j := i + 1 To BalkenZahl Do Begin Application.Processmessages; If recsize2[min] < recsize2[j] Then min := j; End; ... |
Re: Auswahlsort
Ermitteln will ich gar nichts. Wenn min aber kleiner als j ist, soll getauscht werden. Somit kann ich die Balken sortieren. Oder täusche ich mich da?
|
Re: Auswahlsort
natürlich willst du da was ermitteln :shock:
Willst du nicht eigentlich das kleinste Element suchen und an die Position i setzen? |
Re: Auswahlsort
Mhm ... ja also j wird im Endeffekt mit i vertauscht. D.h. in min wird das von i größere Element gespeichert und am Ende der 2. Schleife wird das größte Element j mit i vertauscht.
|
Re: Auswahlsort
Also vielleicht blick ich es auch nicht ganz aber...
du verwendest min mal als index mal als Vergleichsgröße ! mit
Delphi-Quellcode:
weist du min die Länge des Balkens an Position i zu.
min=recsize[i];
mit
Delphi-Quellcode:
verwendest du diesen Längenwert als Index.
If recsize2[min] < recsize2[j] Then min := j;
Irgendwie kann das nicht gewollt sein oder? |
Alle Zeitangaben in WEZ +1. Es ist jetzt 15:44 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz