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.