![]() |
Delphi-Version: 2005
Dynamisches Array of Integer sortieren: welches Sortierverfahren???
Hallo!
Ich habe da ein Array of Integer, das in der Regel nicht mehr als 20-25 Zahlen drin hat. Die Zahlenwete liegen immer zwischen 1 und 128. Nun möchte ich die Zahlen in diesem Array sortieren. Da bin ich auf eine Reihe von Sortiertutorials ( ![]() Danke! |
AW: Dynamisches Array of Integer sortieren: welches Sortierverfahren???
Kommt es hier wirklich auf jede kleine Microsekunde an?
Wie oft wird denn sortiert? Nja, ich würde einfach ein Bubble-Sort implementieren und fertig. Schön einfach und bestimmt ausreichend. Bei den paar "klitzekleinen" Integer könnte schon alleine das Selection-Sort langsamer oder zumindestens gleich schnell sein, so daß sich der Aufand einfach nicht lohnt. |
AW: Dynamisches Array of Integer sortieren: welches Sortierverfahren???
Bucketsort sollte die Aufgabe recht zügig bewältigen ;)
Ansonsten: Diese Datenmenge ist ein Witz für jeden anständigen Algo. Alles außer Slowsort und Bogosort sollte den Job im Nu getan bekommen. |
AW: Dynamisches Array of Integer sortieren: welches Sortierverfahren???
Ich würde hier gar nichts implementieren sondern einfach folgendes aufrufen:
Delphi-Quellcode:
Vorausgesetzt natürlich, man setzt keine veraltete Delphi-Version ein :wink: (Ich sehe gerade, daß dies der Fall ist)
var
MyArray: array of Integer; ... TArray.Sort<Integer>(MyArray); Wenn's denn wirklich an der Performance drückt, kann man die Implementierung immer noch verbessern. Aber jede zusätzliche (und in diesem Fall völlig überflüssige) Implementierung ist eine zusätzliche Fehlerquelle. |
AW: Dynamisches Array of Integer sortieren: welches Sortierverfahren???
Vielen Dank für schnelle Raktionen!
Zitat:
Ich arbeite mittlerweise mit Delphi 2010, muss also klappen. Was muss ich für TArray in uses deklarieren? |
AW: Dynamisches Array of Integer sortieren: welches Sortierverfahren???
Delphi-Quellcode:
uses Generics.Collections;
|
AW: Dynamisches Array of Integer sortieren: welches Sortierverfahren???
Hallo romber,
bei kleinen Zahlenmengen werden die herkömmlichen Sortierverfahren wahrscheinlich schnell genug sein. Der folgende Code beschreibt einen anderen Ansatz für nahezu beliebig große Zahlenmengen mit beschränktem Wertebereich:
Delphi-Quellcode:
Gruß Hawkeye
procedure Sort (var A: array of Integer);
const MINVALUE = 1; MAXVALUE = 128; ERRVALUE = 255; var i, j, k: Integer; Counter: array [MINVALUE..MAXVALUE] of Integer; begin FillChar (Counter, SizeOf(Counter), 0); for i in A do if (i >= MINVALUE) and (i <= MAXVALUE) then Inc (Counter[i]); k := 0; for i := Low(Counter) to High(Counter) do for j := 1 to Counter[i] do begin A[k] := i; Inc (k); end; for j := k to High(A) do A[j] := ERRVALUE; end; |
AW: Dynamisches Array of Integer sortieren: welches Sortierverfahren???
also generell das allerschnellste Sortierverfahren, das es zur Zeit gibt und mir bekannt ist, ist QuickSort.
Delphi bringt auch Demos mit. Da ist eine Thread-Sortier-Demo dabei. Da könntest du mal schauen. Da QuickSort rekursiv arbeitet, wird es etwas Performance schlucken. Wenn du den Stack nicht allzu stark belasten darfst, könnte MinSort (welches schneller ist als BubbleSort) auch zu gebrauchen sein. Bernhard EDIT: Noch was zur Performance:
Delphi-Quellcode:
bei Zahlen unter 256 belegt 3 Byte weniger Speicherplatz pro Element
Array of Byte
|
AW: Dynamisches Array of Integer sortieren: welches Sortierverfahren???
Warum müssen die Daten in "Echtzeit" verarbeitet werden? Für so was eignet sich ein Threadpool, dann kann die Abarbeitung auch mal länger dauern, ohne dass du Probleme bekommst, wenn wieder Daten eintreffen.
|
AW: Dynamisches Array of Integer sortieren: welches Sortierverfahren???
Zitat:
Zitat:
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 13:12 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