WikiDer > Куча теней
В Информатика, а куча теней это объединяемая куча структура данных который поддерживает эффективное слияние кучи в амортизированный смысл. В частности, теневые кучи использовать алгоритм слияния теней для вставки в О(f (п)) амортизированное время и удаление в О((бревно п журнал журнал п) / f (п)) амортизированное время для любого выбора 1 ≤ f (п) ≤ журнал журнал п.[1]
В этой статье предполагается, что А и B двоичные кучи с |А| ≤ |B|.
Слияние теней
Слияние теней - это алгоритм для слияния двух двоичные кучи эффективно, если эти кучи реализованы как массивы. В частности, время работы слияния теней на двух кучах и является .
Алгоритм
Мы хотим объединить две двоичные минимальные кучи и . Алгоритм следующий:
- Объедините массив в конце массива получить массив .
- Определить тень из в ; то есть предки последних узлы в которые разрушают свойство кучи.
- Определите следующие две части тени от :
- В дорожка : набор узлов в тени, для которых не более 2 на любой глубине ;
- В поддерево : остаток тени.
- Извлеките и отсортируйте самые маленькие узлы из тени в массив .
- Преобразовать следующее:
- Если , затем, начиная с наименьшего элемента в отсортированном массиве, последовательно вставьте каждый элемент в , заменив их на мельчайшие элементы.
- Если , затем извлеките и отсортируйте самые маленькие элементы из , и объедините этот отсортированный список с .
- Заменить элементы в исходное положение в .
- Сделайте кучу из .
Продолжительность
Опять же, пусть обозначим путь, а обозначают поддерево объединенной кучи . Количество узлов в не более чем вдвое глубже , который . Причем количество узлов в на глубине составляет не более 3/4 количества узлов на глубине , поэтому поддерево имеет размер . Поскольку на каждом уровне не более 2 узлов. , затем читая самый маленький элементы тени в отсортированный массив берет время.
Если , затем объединяя и как в шаге 5 выше требует времени . В противном случае время, затраченное на этот шаг, равно . Наконец, делаем кучу поддерева берет время. Это составляет общее время выполнения теневого слияния .
Структура
Куча теней состоит из пороговой функции , и множество для которых реализован обычный массив двоичная куча Свойство сохраняется в его первых записях, и для которого свойство кучи не обязательно поддерживается в других записях. Таким образом, теневая куча - это, по сути, двоичная куча. рядом с массивом . Чтобы добавить элемент в теневую кучу, поместите его в массив . Если массив становится слишком большим в соответствии с указанным порогом, мы сначала создаем кучу из с помощью Алгоритм Флойда для строительства кучи,[2] а затем объедините эту кучу с используя слияние теней. Наконец, слияние теневых куч просто выполняется путем последовательной вставки одной кучи в другую с использованием описанной выше процедуры вставки.
Анализ
Нам дана куча теней , с пороговой функцией как указано выше. Предположим, что пороговая функция такова, что любое изменение вызывает не большее изменение, чем в . Мы выводим желаемые границы времени работы для объединяемая куча операции с использованием потенциальный метод за амортизированный анализ. Потенциал кучи выбрано:
Используя этот потенциал, мы можем получить желаемое амортизированное время работы:
Создайте(ЧАС): инициализирует новую пустую теневую кучу
- Здесь потенциал не изменилась, поэтому амортизированная стоимость создания равна , фактическая стоимость.
вставлять(Икс, ЧАС): вставки в кучу теней
- Есть два случая:
- Если используется слияние, то падение потенциальной функции - это в точности фактическая стоимость слияния. и , поэтому амортизированная стоимость равна .
- Если слияние не происходит, амортизированная стоимость равна
- Таким образом, путем выбора пороговой функции получаем, что амортизированная стоимость вставки составляет:
delete_min (ЧАС): удаляет элемент с минимальным приоритетом из
- Поиск и удаление минимума занимает реальное время . Более того, потенциальная функция может увеличиваться после этого удаления только в том случае, если значение уменьшается. По выбору , получаем, что амортизированная стоимость этой операции совпадает с фактической стоимостью.
Связанные алгоритмы и структуры данных
Наивный алгоритм слияния двоичной кучи объединит две кучи и во время просто объединив обе кучи и сделав кучу из полученного массива, используя Алгоритм Флойда для строительства кучи. В качестве альтернативы, кучи можно просто объединить, последовательно вставив каждый элемент в , не торопясь .
Мешок и Стрототт предложил алгоритм объединения двоичных куч в время.[3] Известно, что их алгоритм более эффективен, чем второе наивное решение, описанное выше, примерно когда . Слияние теней работает асимптотически лучше, чем их алгоритм, даже в худшем случае.
Есть несколько других куч, которые поддерживают более быстрое время слияния. Например, Куча Фибоначчи можно объединить время. Поскольку двоичные кучи требуют время сливаться,[4] слияние теней остается эффективным.
Рекомендации
- ^ Кузмауль, Кристофер Л. (2000). Эффективные операции слияния и вставки для двоичных куч и деревьев (PDF) (Технический отчет). Подразделение NASA Advanced Supercomputing. 00-003.
- ^ Сученек, Марек А. (2012), «Элементарный, но точный анализ наихудшего случая программы строительства кучи Флойда», Fundamenta Informaticae, IOS Press, 120 (1): 75–92, Дои:10.3233 / FI-2012-751
- ^ Sack, Jörg-R .; Стрототт, Томас (1985), "Алгоритм слияния куч", Acta Informatica, Springer-Verlag, 22 (2): 171–186, Дои:10.1007 / BF00264229.
- ^ Кормен, Томас Х.; Лейзерсон, Чарльз Э.; Ривест, Рональд Л. (1990). Введение в алгоритмы (1-е изд.). MIT Press и McGraw-Hill. ISBN 0-262-03141-8.