DAA - szybkie sortowanie
Jest używany na zasadzie dziel i rządź. Szybkie sortowanie to algorytm z wyboru w wielu sytuacjach, ponieważ nie jest trudny do wdrożenia. Jest to dobre sortowanie ogólnego przeznaczenia i zużywa stosunkowo mniej zasobów podczas wykonywania.
Zalety
Jest na miejscu, ponieważ wykorzystuje tylko mały stos pomocniczy.
Wymaga tylko n (log n) czas posortować n przedmiotów.
Posiada wyjątkowo krótką pętlę wewnętrzną.
Algorytm ten został poddany dogłębnej analizie matematycznej, można bardzo precyzyjnie stwierdzić o problemach z wydajnością.
Niedogodności
Jest rekurencyjny. Szczególnie jeśli rekursja nie jest dostępna, implementacja jest niezwykle skomplikowana.
W najgorszym przypadku wymaga to czasu kwadratowego (tj. N2).
Jest kruchy, tzn. Zwykły błąd w implementacji może pozostać niezauważony i spowodować złe działanie.
Szybkie sortowanie polega na podzieleniu danej tablicy na partycje A[p ... r] na dwie niepuste pod tablice A[p ... q] i A[q+1 ... r] takie, że każdy klucz A[p ... q] jest mniejsze lub równe każdemu kluczowi A[q+1 ... r].
Następnie dwie tablice podrzędne są sortowane według rekurencyjnych wywołań funkcji Szybkie sortowanie. Dokładna pozycja partycji zależy od podanej tablicy i indeksuq jest obliczany jako część procedury partycjonowania.
Algorithm: Quick-Sort (A, p, r)
if p < r then
q Partition (A, p, r)
Quick-Sort (A, p, q)
Quick-Sort (A, q + r, r)
Zauważ, że aby posortować całą tablicę, początkowe wywołanie powinno być Quick-Sort (A, 1, length[A])
W pierwszej kolejności funkcja Szybkie sortowanie wybiera jeden z elementów tablicy do posortowania jako przestawny. Następnie macierz jest dzielona na partycje po obu stronach osi. Elementy, które są mniejsze lub równe pivot, będą przesuwać się w lewo, podczas gdy elementy, które są większe lub równe pivot będą przesuwać się w prawo.
Partycjonowanie tablicy
Procedura partycjonowania reorganizuje pod-tablice w miejscu.
Function: Partition (A, p, r)
x ← A[p]
i ← p-1
j ← r+1
while TRUE do
Repeat j ← j - 1
until A[j] ≤ x
Repeat i← i+1
until A[i] ≥ x
if i < j then
exchange A[i] ↔ A[j]
else
return j
Analiza
Najgorszy przypadek złożoności algorytmu szybkiego sortowania to O(n2). Jednak używając tej techniki, w przeciętnych przypadkach generalnie otrzymujemy wynikO(n log n) czas.