Skip to content

Sortowanie odd-even

Sortowanie nieparzysto-parzyste (ang. Odd-even), znane również jako sortowanie bąbelkowe dwufazowe lub sortowanie Brick Sort, to algorytm sortujący, który działa na zasadzie porównywania wszystkich par elementów nieparzysto-parzystych (indeksy są parzyste lub nieparzyste) listy, które następnie, jeśli są w złej kolejności, są zamieniane miejscami. Ta operacja jest powtarzana, aż lista zostanie posortowana.

Algorytm sortowania nieparzysto-parzystego składa się z następujących kroków:

  • Faza nieparzysta: przeglądaj całą listę i dla każdej pary elementów na nieparzystych pozycjach \(i\), jeżeli element na pozycji \(i\) jest większy od elementu na pozycji \(i+1\), zamień je miejscami.

  • Faza parzysta: przeglądaj całą listę i dla każdej pary elementów na parzystych pozycjach \(i\), jeżeli element na pozycji \(i\) jest większy od elementu na pozycji \(i+1\), zamień je miejscami.

  • Powtarzaj fazy: powtarzaj powyższe fazy, aż lista zostanie całkowicie posortowana.

Algorytm ten kontynuuje te dwie fazy, dopóki nie posortuje całej listy. Głównym założeniem jest to, że po każdej iteracji najmniejszy element porusza się co najmniej o jedną pozycję do przodu.

Poniżej znajdziesz animację przedstawiającą ideę omawianego algorytmu.

Animacja

Sortowanie odd-even

Solution

Pseudocode

procedura OddEvenSort(n, A):
    1. Od i := 1 do n, wykonuj:
        2. Jeżeli i mod 2 = 1, to:
            3. Dla j := 2 do n, z krokiem 2, wykonuj:
                4. Jeżeli A[j] < A[j - 1]:
                    5. Zamień(A[j], A[j - 1])
        6. w przeciwnym przypadku:
            7. Dla j := 1 do n, z krokiem 2, wykonuj:
                8. Jeżeli A[j] < A[j - 1]:
                    9. Zamień(A[j], A[j - 1])

Block diagram

%%{init: {"flowchart": {"curve": "linear"}, "theme": "neutral"} }%%
flowchart TD
    START(["OddEvenSort(n, A)"]) --> K0[i := 1]
    K0 --> K1{i <= n}
    K1 -- TRUE --> K2{i mod 2 = 1}
    K2 -- TRUE --> K3p[j := 2]
    K3p --> K3{j <= n}
    K3 -- TRUE --> K4{"A[j] < A[j - 1]"}
    K4 -- TRUE --> K5["Zamień(A[j], A[j - 1])"]
    K5 --> K3i[j := j + 2]
    K4 -- FALSE --> K3i
    K3i --> K3
    K3 -- FALSE --> K1i[i := i + 1]
    K2 -- FALSE --> K7p[j := 1]
    K7p --> K7{j <= n}
    K7 -- TRUE --> K8{"A[j] < A[j - 1]"}
    K8 -- TRUE --> K9["Zamień(A[j], A[j - 1])"]
    K9 --> K7i[j := j + 2]
    K8 -- FALSE --> K7i
    K7i --> K7
    K7 -- FALSE --> K1i
    K1i --> K1
    K1 -- FALSE -------> STOP([STOP])

Complexity

Algorytm sortowania nieparzysto-parzystego ma złożoność obliczeniową \(O(n^2)\), zarówno w przypadku średnim, jak i najgorszym. Jest to więc algorytm nieefektywny dla dużych zestawów danych.

Implementation

C++

Python

Kotlin