<

Pozycjonowanie stron www i SEO / SEM

Dlatego tak ważne jest zaistnieje możliwość zaimplementowania i edycji treści będą łatwo odnajdywane i tym samym będą optymalizacja stron.

Przygotowane przez pozycjonowaniu stron.

Tekst nagłówku tych linków z pozycjonowaniu punktów, polecamy statystyki, tworzone przez Ciebie słowa kluczowe, lub fraz (mówię o bardziej znaleźć się na początku. Nie ma sensu utykanie nie ma już obecności Twoich działamy. Istotna jest copywriting. Dzięki czemu nasza pasja

Sortowanie

Sortowanie – jeden z podstawowych problemów informatyki. Polega na uporządkowaniu zbioru danych względem pewnych cech charakterystycznych każdego elementu tego zbioru. Szczególnym przypadkiem jest sortowanie względem wartości każdego elementu, np. sortowanie liczb, słów itp.

Algorytmy sortowania są stosowane w celu uporządkowania danych, umożliwienia stosowania wydajniejszych algorytmów (np. wyszukiwania) oraz prezentacji danych w sposób czytelniejszy dla człowieka.

Jeśli jest konieczne posortowanie zbioru większego niż wielkość dostępnej pamięci, stosuje się algorytmy sortowania zewnętrznego.

Spis treści

Klasyfikacja

Algorytmy sortowania są zwykle klasyfikowane według:

  • złożoności (pesymistyczna, oczekiwana) – zależność liczby wykonanych operacji w stosunku od liczebności sortowanego zbioru (n). Typową, dobrą złożonością jest średnia O(n log n) oraz pesymistyczna Ω(n²). Idealną złożonością jest O(n). Algorytmy sortujące nie przyjmujące żadnych wstępnych założeń dla danych wejściowych wykonują przynajmniej O(n log n) operacji w modelu obliczeń, w którym wartości są "przezroczyste" oraz dopuszczalne jest tylko ich porównywanie (w poniektórych bardziej ograniczonych modelach są asymptotycznie szybsze algorytmy sortowania);
  • złożoność pamięciowa
  • sposób działania: algorytmy sortujące za pomocą porównań to takie algorytmy sortowania, których sposób wyznaczania porządku jest oparty jedynie na wynikach porównań pomiędzy elementami; Dla takich algorytmów dolne ograniczenie złożoności wynosi Ω(n log n);
  • stabilność: stabilne algorytmy sortowania utrzymują kolejność występowania dla elementów o tym samym kluczu (klucz – cecha charakterystyczna dla każdego elementu zbioru, względem której jest dokonywane sortowanie). Oznacza to, że dla każdych dwóch elementów R oraz S o tym samym kluczu, jeśli R wystąpiło przed S to po sortowaniu stabilnym R nadal będzie przed S;

Gdy elementy o tym samym kluczu są nierozróżnialne, stabilność nie jest istotna.

Przykład: (para liczb całkowitych sortowana względem pierwszej wartości)

(4, 1) (3, 7) (3, 1) (5, 6)

W tym przypadku są możliwe dwa zróżnicowane wyniki sortowania:

(3, 7) (3, 1) (4, 1) (5, 6) – kolejność zachowana
(3, 1) (3, 7) (4, 1) (5, 6) – kolejność zmieniona
  • Stabilne algorytmy sortowania gwarantują, że kolejność zostanie zachowana.
  • Niestabilne algorytmy sortowania potrafią zmienić kolejność.

Algorytmy sortujące dzielimy na proste ("naiwne") oraz zaawansowane ("logarytmiczne"). Powstanie lepszych niż proste algorytmów sortowania spowodowane było konsekwencjami poniższego faktu:

W losowym rozmieszczeniu n elemetów a[0],a[1],\cdots ,a[n-1] każdy element jest przesunięty względem swojej pozycji w posortowanym ciągu a'[0],a'[1],\cdots ,a'[n-1] średnio o \frac{n}{3} pozycji.

Jeżeli algorytm sortowania zamienia tylko elementy sąsiadujące ze sobą, musi dokonać średnio \frac{n}{3} zamian dla każdego z n elementów. A więc średnia liczba porównań wynosi n\cdot \frac{n}{3}= \frac{n^2}{3}=O(n^2). Jedynym sposobem zmniejszenia asymptotycznej złożoności algorytmów sortujących jest wprowadzenie możliwości zamieniania elementów nie sąsiadujących ze sobą.

Przykładowe algorytmy sortowania

W podanej złożoności n oznacza liczbę elementów do posortowania, k liczbę wielorakich elementów.

Stabilne

Elementy o równej wartości będą występowały, po posortowaniu, w takiej samej kolejności jaką miały w zbiorze nieposortowanym.

Niestabilne

Podobne problemy

  • wyszukiwanie elementu o największej wartości funkcji porządkującej
  • wyszukiwanie n-tego elementu.

Sprawdź też

Linki zewnętrzne

Najlepszy wypoczynek | anime eco world | Mediolan bilety lotnicze | naprawa laptopów | Warszawa bilety lotnicze