Zalety i wady sortowania bąbelkowego

Programiści, którzy przestawiają się z tworzenia komputerów i stron internetowych na kodowanie dla urządzeń mobilnych lub systemów wbudowanych, zauważają, że więcej czasu spędzają na wybieraniu i kodowaniu własnych struktur danych i algorytmów. Mniejsza ilość pamięci i ograniczone miejsce do przechowywania danych sprawiają, że nie ma miejsca na gotowe biblioteki lub frameworki. Tak więc dla tych, którzy muszą napisać własne procedury sortowania, oto kilka rozważań na temat wyboru niskiego sortowania bąbelkowego.

Tło

Sortowanie bąbelkowe to prosty algorytm, który sortuje listę elementów w pamięci. Biorąc pod uwagę tablicę, kod wielokrotnie porównuje każdą parę sąsiednich elementów i zamienia je, jeśli nie są w kolejności. Proces powtarza się, dopóki nie nastąpi żadna wymiana. Gdyby można było wyświetlić tablicę w trakcie sortowania, niskie wartości „przeskakiwałyby” na górę, podczas gdy duże wartości opadałyby na dół. Oto odpowiedni kod w Visual Basic 2010:

Wideo dnia

While swap = True swap = False For i = 0 To tbl.length - 2 If tbl (i) > tbl (i + 1) Then tmp = tbl (i) tbl (i) = tbl (i + 1) tbl (i + 1) = tmp swap = True End If Next End While

Kiedy wybrać sortowanie bąbelkowe?

Ten algorytm ma kilka zalet. Jest prosty do napisania, łatwy do zrozumienia i zajmuje tylko kilka linijek kodu. Dane są sortowane w miejscu, więc nakład pamięci jest niewielki, a po posortowaniu dane znajdują się w pamięci, gotowe do przetwarzania. Główną wadą jest czas potrzebny na sortowanie. Średni czas rośnie niemal wykładniczo wraz ze wzrostem liczby elementów tabeli. Dziesięciokrotna liczba elementów zajmuje prawie sto razy dłużej, aby sortować.

Inne rodzaje tablic

Algorytmy sortowania różnią się złożonością, szybkością i narzutem. Sortowanie bąbelkowe jest najmniej złożone, ale także jednym z najwolniejszych. Inne sortowania oparte na tablicach, takie jak sortowanie przez wstawianie i sortowanie z wymianą, są nieco szybsze, ale wymagają więcej kodu (patrz odniesienia poniżej). Główną zaletą sortowania opartego na tablicach jest to, że zużywają najmniej kodu i zajmują najmniej pamięci roboczej. Rozważ te rodzaje dla prostych tablic zawierających mniej niż kilkaset elementów.

Złożone algorytmy sortowania

Większe zestawy danych wymagają bardziej złożonego kodu i większej ilości pamięci. Szybkie sortowanie i sortowanie na stercie zarówno dzielą, jak i kopiują zestawy danych, aby zoptymalizować liczbę porównań. Szybkie sortowanie w sposób ciągły dzieli listę, a następnie składa ją ponownie w kolejności sortowania. Sortowanie na stercie kopiuje dane do struktury drzewa, a następnie przechodzi przez drzewo, aby skopiować dane z powrotem do porządku. Oba są szybkie i wydajne, ale zajmują więcej kodu i znacznie więcej miejsca do pracy. Wybierz te algorytmy dla dużych zbiorów danych.