Блинная сортировка

Блинная сортировка (от англ. pancake sorting) — алгоритм сортировки. Единственная операция, допустимая в алгоритме — переворот элементов последовательности до какого-либо индекса. В отличие от традиционных алгоритмов, в которых минимизируют количество сравнений, в блинной сортировке требуется сделать как можно меньше переворотов. Процесс можно визуально представить как стопку блинов, которую тасуют путём взятия нескольких блинов сверху и их переворачивания.
Алгоритм
Простейший алгоритм (вариант сортировки выбором) даёт не более [math]\displaystyle{ 2n-3 }[/math] переворотов, однако требует поиска наибольшего элемента[1]. В 1979 году Билл Гейтс и Христос Пападимитриу представили свой алгоритм и доказали достаточность [math]\displaystyle{ (5n+5)/3 }[/math] переворотов и необходимость [math]\displaystyle{ 17n/16 }[/math][2]. В 1997 году Хейдари и Судборог показали нижнюю границу в [math]\displaystyle{ 15n/14 }[/math]. Они представили точные значения вплоть до [math]\displaystyle{ N=13 }[/math], для которого требуется 15 переворотов[3]. Значительно (до [math]\displaystyle{ 18n/11 }[/math]) превзойти результат Гейтса и Пападимитриу получилось только в 2008 году у группы исследователей из Техасского университета в Далласе под руководством Судборога[4][5].
Задача о подгоревших блинах
Усложнённый вариант представляет собой блинную сортировку последовательности, элементы которой содержат дополнительный бинарный параметр. Эту задачу предложили Билл Гейтс и Христос Пападимитриу в 1979 году[2]. Она стала известна как «задача о подгоревших блинах» (англ. burnt pancake problem):
Каждый блин в стопке подгорел с одной стороны. Требуется отсортировать блины по возрастанию (убыванию) диаметра так, чтобы они все лежали на тарелке подгоревшей стороной вниз.
В 2007 году группа студентов создала биокомпьютер на основе генетически модифицированной кишечной палочки (E. coli), который решал задачу о подгорелых блинах. Роль блинов играли фрагменты дезоксирибонуклеиновой кислоты (3′- и 5′-концы которых обозначали разные стороны блина). Бактерия, выстроив фрагменты в нужном порядке, приобретала устойчивость к антибиотику и не погибала. Время, затраченное на поиск правильной комбинации, показывало минимально необходимое число переворотов фрагмента[6][7].
Реализация
Примечания
- ↑ Douglas B. West. The Pancake Problems (1975, 1979, 1973) (англ.). Дата обращения: 16 августа 2009. Архивировано 5 апреля 2012 года.
- ↑ Перейти обратно: 2,0 2,1 William H. Gates; Christos H. Papadimitriou. Bounds for sorting by prefix reversal (англ.) // Discrete Mathematics. — 1979. — Iss. 27. — P. 47—57. Архивировано 10 июня 2007 года.
- ↑ Mohammad H. Heydari; I. Hal Sudborough. On the diameter of the pancake network (англ.) // Journal of Algorithms. — Дулут: Academic Press, Inc, 1997. — Vol. 25, iss. 1. — P. 67—94.
- ↑ Team Bests Young Bill Gates With Improved Answer to So-Called Pancake Problem in Mathematics (англ.) (17 сентября 2008). Дата обращения: 16 августа 2009. Архивировано 5 апреля 2012 года.
- ↑ B. Chitturi, W. Fahle, Z. Meng, L. Morales, C. O. Shields, I. H. Sudborough, W. Voit. An (18/11)n upper bound for sorting by prefix reversals (англ.) // Theoretical Computer Science. — Эссекс: Elsevier Science Publishers Ltd., 2009. — Vol. 410, iss. 36. — P. 3372—3390.
- ↑ Karmella A. Haynes, Marian L. Broderick, Adam D. Brown et al. Engineering bacteria to solve the Burnt Pancake Problem (англ.) // Journal of Biological Engineering. — 2008. — Vol. 2, iss. 8.
- ↑ Анимационный ролик, объясняющий решение задачи биологическим компьютером (англ.). Дата обращения: 16 августа 2009. Архивировано 5 апреля 2012 года.
См. также
Ссылки
- Weisstein, Eric W. Pancake Sorting (англ.). MathWorld. Дата обращения: 16 августа 2009.
- Alexander Bogomolny. Flipping pancakes (англ.). Дата обращения: 16 августа 2009. Архивировано 5 апреля 2012 года.