WikiDer > Сортировка бисера
Эта статья поднимает множество проблем. Пожалуйста помоги Улучши это или обсудите эти вопросы на страница обсуждения. (Узнайте, как и когда удалить эти сообщения-шаблоны) (Узнайте, как и когда удалить этот шаблон сообщения)
|
Сортировка бисера, также называемый гравитационная сортировка, это естественный алгоритм сортировки, разработан Джошуа Дж. Аруланандхам, Кристиан С. Калуд и Майкл Дж. Диннин в 2002 г. и опубликовано в Вестник Европейская ассоциация теоретической информатики. Обе цифровой и аналог аппаратное обеспечение реализации бусинок можно добиться за время сортировки О(п); однако реализация этого алгоритма имеет тенденцию быть значительно медленнее в программного обеспечения и может использоваться только для сортировки списков положительные целые числа. Кроме того, казалось бы, даже в лучшем случае алгоритм требует О(п2) Космос.
Обзор алгоритма
Операцию сортировки шариков можно сравнить с тем, как шарики скользят по параллельным полюсам, например, по счеты. Однако на каждом полюсе может быть разное количество бусинок. Первоначально может быть полезно представить бусинки, подвешенные на вертикальных столбах. На шаге 1 такое расположение отображается с помощью п = 5 ряды бус на м = 4 вертикальные столбы. Цифры справа от каждой строки указывают номер, который представляет данная строка; строки 1 и 2 представляют положительное целое число 3 (потому что каждая из них содержит три бусинки), а верхняя строка представляет положительное целое число 2 (поскольку она содержит только две бусинки).[1]
Если затем мы позволим бусинам упасть, строки теперь представляют те же целые числа в отсортированном порядке. Строка 1 содержит наибольшее число в наборе, а строка п содержит самый маленький. Если указанное выше соглашение о рядах, содержащих ряд бусинок на полюсах 1 ..k и оставляя полюса k+1..м empty, так будет и здесь.
Действие, позволяющее бусинам «падать» в нашем физическом примере, позволило большим значениям из верхних рядов распространиться на нижние ряды. Если значение, представленное строкой а меньше значения, содержащегося в строке а + 1, часть бисера из ряда а + 1 попадет в ряд а; это обязательно произойдет, поскольку строка а не содержит бусинок в тех положениях, чтобы препятствовать бусинкам в ряду а + 1 от падения.
Механизм, лежащий в основе сортировки бусинок, аналогичен механизму, лежащему в основе счетная сортировка; количество бусинок на каждом полюсе соответствует количеству элементов со значением, равным или большим, чем индекс этого полюса.
Сложность
Сортировка бусинок может быть реализована с четырьмя общими уровнями сложности, среди прочего:
- О(1): все шарики перемещаются одновременно в одной и той же единице времени, как в случае с простым физическим примером выше. Это абстрактная сложность, и ее невозможно реализовать на практике.
- О(): В реалистичной физической модели, использующей гравитацию, время, необходимое для того, чтобы шарики упали, пропорционально квадратному корню из максимальной высоты, который пропорционален n.
- О(n): бусинки перемещаются по одному ряду за раз. Это тот случай, который используется в аналоге и цифровое оборудование решения.
- О(S), где S - сумма целых чисел во входном наборе: каждая бусина перемещается индивидуально. Это тот случай, когда сортировка шариков реализована без механизма, помогающего находить пустые места под шариками, например, в программных реализациях.
Словно Сорт голубятни, сортировка бусинок необычна тем, что в худшем случае она может выполняться быстрее, чем О(п бревно п), максимально возможная производительность для сортировка сравнения в худшем случае. Это возможно, потому что ключом для сортировки шариков всегда является положительное целое число, а при сортировке шариков используется его структура.
Выполнение
Эта реализация написана на Python; предполагается, что input_list
будет последовательностью целых чисел. Функция возвращает новый список, а не изменяет переданный, но ее можно тривиально изменить для эффективной работы на месте.
def beadsort(input_list): "" "Сорт бус." "" return_list = [] # Инициализировать "транспонированный список", чтобы он содержал столько элементов, сколько # максимальное значение ввода - фактически, беря самое высокое # столбец входных бусинок и разложить его ровно transposed_list = [0] * Максимум(input_list) за число в input_list: # Для каждого элемента (каждого столбца бусинок) входного списка, # 'уложите бусинки ровно', увеличивая как можно больше элементов # транспонированный список, поскольку столбец высокий. # Они будут накапливаться поверх предыдущих добавлений. transposed_list[:число] = [п + 1 за п в transposed_list[:число]] # Теперь мы уронили бусинки. Для отмены транспонирования мы считаем # 'самый нижний ряд' выпавших бусинок, затем имитируйте удаление этого # строка путем вычитания 1 из каждого «столбца» транспонированного списка. # Когда столбец не достигает высоты текущей строки, # его значение в transposed_list будет <= 0. за _ в input_list: # Подсчет значений> 0 - это то, как мы узнаем, сколько бусинок в # текущая "самая нижняя строка". Обратите внимание, что bools Python могут быть # оценивается как целое; Истина == 1 и Ложь == 0. return_list.добавить(сумма(п > 0 за п в transposed_list)) # Удалите "самую нижнюю строку", вычтя 1 из каждого элемента. transposed_list = [п - 1 за п в transposed_list] # Полученный список сортируется в порядке убывания возвращаться return_list
Ссылки и примечания
- ^ По соглашению, строка, представляющая положительное целое число k на столбах должны быть бусинки 1 ..k и столбы k+1..м должно быть пусто. Это не строгое требование, но, скорее всего, упростит реализацию.
внешняя ссылка
- "Bead-Sort: естественный алгоритм сортировки" (PDF). Архивировано из оригинал (PDF) на 2017-08-09. Получено 2005-01-01. (114 KiB)
- Сортировка бисера в MGS, визуализация сортировки бусинок реализована в MGS язык программирования
- Сортировка бусинок в MathWorld