Stooge sort - Stooge sort - Wikipedia

Stooge sort
Сортировка stoogesort anim.gif
Визуализация сортировки Stooge (показывает только свопы).
Учебный классАлгоритм сортировки
Структура данныхМножество
Худший случай спектакльO (пжурнал 3 / журнал 1,5)
Худший случай космическая сложностьO (п)

Stooge sort это рекурсивный алгоритм сортировки. Он отличается исключительно плохим временная сложность из О (пжурнал 3 / журнал 1,5 ) = O (п2.7095...)Таким образом, время работы алгоритма медленнее, чем у разумных алгоритмов сортировки, и медленнее, чем у Пузырьковая сортировка, канонический пример довольно неэффективной сортировки. Однако это более эффективно, чем Slowsort. Название происходит от Три марионетки.[1]

Алгоритм определяется следующим образом:

  • Если значение в начале больше, чем значение в конце, поменяйте их местами.
  • Если в списке 3 или более элементов, то:
    • Stooge сортирует первые 2/3 списка
    • Stooge сортирует последние 2/3 списка
    • Stooge снова сортирует первые 2/3 списка

Важно получить целочисленный размер сортировки, используемый в рекурсивных вызовах, округлив 2/3 вверх, например округление 2/3 от 5 должно дать 4, а не 3, так как в противном случае сортировка может завершиться ошибкой для определенных данных.

Выполнение

 функция марионетка(множество L, я = 0, j = длина(L)-1){     если L[я] > L[j] тогда       // Если крайний левый элемент больше самого правого элемента         L[я]  L[j]           // Меняем местами крайний левый элемент и крайний правый элемент     если (j - я + 1) > 2 тогда       // Если в массиве минимум 3 элемента         т = этаж((j - я + 1) / 3)         марионетка(L, я  , j-т)  // Сортируем первые 2/3 массива         марионетка(L, я+т, j)    // Сортируем последние 2/3 массива         марионетка(L, я  , j-т)  // Снова сортируем первые 2/3 массива     возвращаться L }

Рекомендации

  1. ^ «CSE 373» (PDF). course.cs.washington.edu. Получено 14 сентября 2020.

Источники

внешняя ссылка