AGB  ·  Datenschutz  ·  Impressum  







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

Auswahlsort

Ein Thema von nothin · begonnen am 5. Jan 2004 · letzter Beitrag vom 5. Jan 2004
Antwort Antwort
Seite 1 von 2  1 2      
Benutzerbild von nothin
nothin

Registriert seit: 18. Okt 2003
21 Beiträge
 
#1

Auswahlsort

  Alt 5. Jan 2004, 13:38
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:
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;
So werden die Balken sortiert ...

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;
n0th!n
--------------------------------------------------
Ziele sind wichtiger als Erinnerungen
--------------------------------------------------
  Mit Zitat antworten Zitat
Minz

Registriert seit: 19. Dez 2002
476 Beiträge
 
#2

Re: Auswahlsort

  Alt 5. Jan 2004, 13:51
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
recsize2[index]:=index irgendwie wenig Sinn

Grüße Minz

OK es sei denn du willst das ganze nur umdrehen !

was genau funktioniert nicht, bzw. was macht er denn?
  Mit Zitat antworten Zitat
Benutzerbild von nothin
nothin

Registriert seit: 18. Okt 2003
21 Beiträge
 
#3

Re: Auswahlsort

  Alt 5. Jan 2004, 13:54
Zitat von Minz:
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
recsize2[index]:=index irgendwie wenig Sinn

Grüße Minz
Die Zeile recsize2[index]:=index 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.
n0th!n
--------------------------------------------------
Ziele sind wichtiger als Erinnerungen
--------------------------------------------------
  Mit Zitat antworten Zitat
Minz

Registriert seit: 19. Dez 2002
476 Beiträge
 
#4

Re: Auswahlsort

  Alt 5. Jan 2004, 13:58
siehe Edit oben
  Mit Zitat antworten Zitat
Benutzerbild von nothin
nothin

Registriert seit: 18. Okt 2003
21 Beiträge
 
#5

Re: Auswahlsort

  Alt 5. Jan 2004, 14:03
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?
n0th!n
--------------------------------------------------
Ziele sind wichtiger als Erinnerungen
--------------------------------------------------
  Mit Zitat antworten Zitat
Minz

Registriert seit: 19. Dez 2002
476 Beiträge
 
#6

Re: Auswahlsort

  Alt 5. Jan 2004, 14:13
Delphi-Quellcode:
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;
...
Willst du da das Minimum oder das Maximum ermitteln?
  Mit Zitat antworten Zitat
Benutzerbild von nothin
nothin

Registriert seit: 18. Okt 2003
21 Beiträge
 
#7

Re: Auswahlsort

  Alt 5. Jan 2004, 14:22
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?
n0th!n
--------------------------------------------------
Ziele sind wichtiger als Erinnerungen
--------------------------------------------------
  Mit Zitat antworten Zitat
Minz

Registriert seit: 19. Dez 2002
476 Beiträge
 
#8

Re: Auswahlsort

  Alt 5. Jan 2004, 14:29
natürlich willst du da was ermitteln

Willst du nicht eigentlich das kleinste Element suchen und an die Position i setzen?
  Mit Zitat antworten Zitat
Benutzerbild von nothin
nothin

Registriert seit: 18. Okt 2003
21 Beiträge
 
#9

Re: Auswahlsort

  Alt 5. Jan 2004, 14:32
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.
n0th!n
--------------------------------------------------
Ziele sind wichtiger als Erinnerungen
--------------------------------------------------
  Mit Zitat antworten Zitat
Minz

Registriert seit: 19. Dez 2002
476 Beiträge
 
#10

Re: Auswahlsort

  Alt 5. Jan 2004, 14:45
Also vielleicht blick ich es auch nicht ganz aber...

du verwendest min mal als index mal als Vergleichsgröße !

mit
min=recsize[i]; weist du min die Länge des Balkens an Position i zu.

mit
If recsize2[min] < recsize2[j] Then min := j; verwendest du diesen Längenwert als Index.

Irgendwie kann das nicht gewollt sein oder?
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 03:20 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