Zitat von
Codix32:
Zitat von
Luckie:
Was ist mit miner Lösung?
DANKE LUCKIE!
Dein Code funzt einwandfrei, ich bin begeistert.
Du bist wohl auch beruflich Programmierer.
Hier bin ich wieder. Nichts für ungut, aber die Routine mit Bubblesort ist sehr sehr langsam.
Ich greife also hier wieder auf 'Listbox.sorted' zurück:
Delphi-Quellcode:
procedure TForm1.sortListe3(L:TListbox);
var i: integer;
Zeilendatum:String;
Zeilenrest:string;
temp:string;
doubleTmp:double;
begin
for i := 0 to L.items.count-1 do
begin
doubleTmp:= strtodate(copy(L.Items[i],1,10));
temp:=floattostr(doubleTmp);
if length(temp)=1 then temp:='000000'+temp;
if length(temp)=2 then temp:='00000'+temp;
if length(temp)=3 then temp:='0000'+temp;
if length(temp)=4 then temp:='000'+temp;
if length(temp)=5 then temp:='00'+temp;
if length(temp)=6 then temp:='0'+temp;
ZeilenDatum:= temp;
Zeilenrest:= copy(L.Items[i],11,length(L.Items[i]));
L.Items[i]:=Zeilendatum +' '+ Zeilenrest;
end;
L.sorted:=true;
for i := 0 to L.items.count-1 do
begin
doubleTmp:= strtofloat(Trim(copy(L.Items[i],1,10)));
ZeilenDatum:= datetostr(doubleTmp);//+' '+floattostr(doubleTmp);
Zeilenrest:= copy(L.Items[i],11,length(L.Items[i]));
L.Items[i]:= Zeilendatum +' '+ Zeilenrest;
end;
end;
Obwohl die Items durch 2 Schleifen laufen, ist damit ruckizucki sortiert. Es wird das Datum als Double-Zahlenwert an den Anfang jedes Items geschrieben, danach sortiert und in der 2. Schleife der Zahlenwert wieder entfernt.
Obwohl das 'Werk' funzt, gefällt es mir nicht. Gibts noch einen anderen Ansatz?
Ist die Delphi interne Function 'Sorted' eigentlich in Assembler geschrieben und wenn ja, wer hat den Quelltext? Die Funktion ist sehr schnell und daher interessant.
Was meint ihr?