AGB  ·  Datenschutz  ·  Impressum  







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

sortieren durch blub oder so??...

Ein Thema von n00b2key · begonnen am 8. Jan 2003 · letzter Beitrag vom 8. Jan 2003
Antwort Antwort
n00b2key

Registriert seit: 2. Jan 2003
11 Beiträge
 
#1

sortieren durch blub oder so??...

  Alt 8. Jan 2003, 17:22
ich habe in einem grid links immer die nummer des dazugehörigen datensatzes. wenn ein datensatz gelöscht wird, werden die nummern automatisch auch aktualisiert.

1) ist mein MOD von bubblesort besser oder standart bubblesort?
normalerweise müsste der folgende code schneller sein, da er nicht unnötig die daten verschiebt.
2) Ist quicki schneller?
Code:
procedure SortIntGrid(var Grid: TStringGrid; ThatCol: Integer);
var i,j,k :Integer;
    hilfArray:array of string;
begin
  SetLength(hilfArray,Grid.ColCount); // bestimmt die länge des arrays - wieviel
  for i := 1 to Grid.RowCount -1 DO   // strings zwischenspeichern (für jede spalte 1)
    for j := i to Grid.RowCount DO
      if Grid.Cells[ThatCol,j] = IntToStr(i) then
      begin
        for k := Low(hilfArray) to High(hilfArray) DO
        begin
          hilfArray[k] := Grid.Cells[k,j];
          Grid.Cells[k,j] := Grid.Cells[k,i];
          Grid.Cells[k,i] := hilfArray[k];
        end;
        break;
      end;
end;
standart blub:
Code:
procedure SortIntGrid(var Grid: TStringGrid; ThatCol: Integer);
var i,j,k :Integer;
    hilfArray:array of string;
begin
  SetLength(hilfArray,Grid.ColCount);
  for i := 1 to Grid.RowCount -1 DO
    for j := i + 1 to Grid.RowCount DO
      if Grid.Cells[ThatCol,j] < IntToStr(i) then
      begin
        for k := Low(hilfArray) to High(hilfArray) DO
        begin
          hilfArray[k] := Grid.Cells[k,j];
          Grid.Cells[k,j] := Grid.Cells[k,i];
          Grid.Cells[k,i] := hilfArray[k];
        end;
        break;
      end;
end;
Ich bin n00b und das ist auch gut so!
  Mit Zitat antworten Zitat
Benutzerbild von phlux
phlux

Registriert seit: 4. Nov 2002
Ort: Witten
1.335 Beiträge
 
Delphi 6 Personal
 
#2
  Alt 8. Jan 2003, 19:10
am besten du misst einfach die zeit während des sortierens, dann findest du heraus welches besser ist. Quicksort is glaub ich besser, zumindest als bubblesort allemal, es gibt auch noch "Shellie" also Shellsort, die is auch noch gut.
Christian "phlux" Arndt
  Mit Zitat antworten Zitat
Sebastian Nintemann
(Gast)

n/a Beiträge
 
#3
  Alt 8. Jan 2003, 19:15
Hi, ich hab mir das jetzt zwar nicht genau angeguckt, trotzdem ein Tipp: sowas kann man ganz gut mit GetTickCount (liefert Millisekunden seit Systemstart) testen. Du legst dir eine Integer-Variable an und setzt diese vor dem durchlaufen der Procedure so
Code:
start := GetTickCount;
auf die Anzahl der ms.
Nach dem Durchlaufen kannst du dir dann mit
Code:
Caption := IntToStr(GetTickCount-start);
die Zeit ansehen, die deine Procedure benötigt hat. Das kann manchmal schon aufschlussreich sein.

Gruß, Sebastian
  Mit Zitat antworten Zitat
Christian Seehase
(Co-Admin)

Registriert seit: 29. Mai 2002
Ort: Hamburg
11.105 Beiträge
 
Delphi 11 Alexandria
 
#4
  Alt 8. Jan 2003, 21:04
Moin Zusammen,

ausserdem hat Daniel hier noch eine grössere Abhandlung zum Thema Sortierverfahren geschrieben.

Ich weiss jetzt nur nicht genau, ob in der Code Library, oder den Tutorials.
Tschüss Chris
Die drei Feinde des Programmierers: Sonne, Frischluft und dieses unerträgliche Gebrüll der Vögel.
Der Klügere gibt solange nach bis er der Dumme ist
  Mit Zitat antworten Zitat
Benutzerbild von phlux
phlux

Registriert seit: 4. Nov 2002
Ort: Witten
1.335 Beiträge
 
Delphi 6 Personal
 
#5
  Alt 8. Jan 2003, 21:05
Moin ich würds lieber so machen:
Delphi-Quellcode:
var
  c,
  n1,
  n2: TLargeInteger
  i: Integer;

begin
  QueryPerformanceFrequerncy(c);
  QueryPerformanceCounter(n1);
  //Hier die aktion starten die gemessen werden soll
  QueryPerformanceCounter(n2);
  Label1.Caption := Format('Zeit: %g',[(n2-n1)/c]);
end;
hab ich mal so ausm DKochbuch genommen, dürfte funzen falls nicht G* beschwert euch bei D&K
Christian "phlux" Arndt
  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:11 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