Куча теней - Shadow heap

В Информатика, а куча теней это объединяемая куча структура данных который поддерживает эффективное слияние кучи в амортизированный смысл. В частности, теневые кучи использовать алгоритм слияния теней для вставки в О (f (п)) амортизированное время и удаление в О((бревно п журнал журнал п) / f (п)) амортизированное время для любого выбора 1 ≤ f (п) ≤ журнал журнал п.[1]

В этой статье предполагается, что А и B двоичные кучи с |А| ≤ |B|.

Слияние теней

Слияние теней - это алгоритм для слияния двух двоичные кучи эффективно, если эти кучи реализованы как массивы. В частности, время работы слияния теней на двух кучах и является .

Алгоритм

Мы хотим объединить две двоичные минимальные кучи и . Алгоритм следующий:

  1. Объедините массив в конце массива получить массив .
  2. Определить тень из в ; то есть предки последних узлы в которые разрушают свойство кучи.
  3. Определите следующие две части тени от :
    • В дорожка : набор узлов в тени, для которых не более 2 на любой глубине ;
    • В поддерево : остаток тени.
  4. Извлеките и отсортируйте самые маленькие узлы из тени в массив .
  5. Преобразовать следующее:
    • Если , затем, начиная с наименьшего элемента в отсортированном массиве, последовательно вставьте каждый элемент в , заменив их на мельчайшие элементы.
    • Если , затем извлеките и отсортируйте самые маленькие элементы из , и объедините этот отсортированный список с .
  6. Заменить элементы в исходное положение в .
  7. Сделайте кучу из .

Продолжительность

Опять же, пусть обозначим путь, а обозначают поддерево объединенной кучи . Количество узлов в не более чем вдвое глубже , который . Причем количество узлов в на глубине составляет не более 3/4 количества узлов на глубине , поэтому поддерево имеет размер . Поскольку на каждом уровне не более 2 узлов. , затем читая самый маленький элементы тени в отсортированный массив берет время.

Если , затем объединяя и как в шаге 5 выше требует времени . В противном случае время, затраченное на этот шаг, равно . Наконец, делаем кучу поддерева берет время. Это составляет общее время выполнения теневого слияния .

Структура

Куча теней состоит из пороговой функции , и множество для которых реализован обычный массив двоичная куча Свойство сохраняется в его первых записях, и для которого свойство кучи не обязательно поддерживается в других записях. Таким образом, теневая куча - это, по сути, двоичная куча. рядом с массивом . Чтобы добавить элемент в теневую кучу, поместите его в массив . Если массив становится слишком большим в соответствии с указанным порогом, мы сначала создаем кучу из с помощью Алгоритм Флойда для строительства кучи,[2] а затем объедините эту кучу с используя слияние теней. Наконец, слияние теневых куч просто выполняется путем последовательной вставки одной кучи в другую с использованием описанной выше процедуры вставки.

Анализ

Нам дана куча теней , с пороговой функцией как указано выше. Предположим, что пороговая функция такова, что любое изменение вызывает не большее изменение, чем в . Мы выводим желаемые границы времени работы для объединяемая куча операции с использованием потенциальный метод за амортизированный анализ. Потенциал кучи выбрано:

Используя этот потенциал, мы можем получить желаемое амортизированное время работы:

Создайте(ЧАС): инициализирует новую пустую теневую кучу

Здесь потенциал не изменилась, поэтому амортизированная стоимость создания равна , фактическая стоимость.

вставлять(Икс, ЧАС): вставки в кучу теней

Есть два случая:
  • Если используется слияние, то падение потенциальной функции - это в точности фактическая стоимость слияния. и , поэтому амортизированная стоимость равна .
  • Если слияние не происходит, амортизированная стоимость равна
Таким образом, путем выбора пороговой функции получаем, что амортизированная стоимость вставки составляет:

delete_min (ЧАС): удаляет элемент с минимальным приоритетом из

Поиск и удаление минимума занимает реальное время . Более того, потенциальная функция может увеличиваться после этого удаления только в том случае, если значение уменьшается. По выбору , получаем, что амортизированная стоимость этой операции совпадает с фактической стоимостью.

Связанные алгоритмы и структуры данных

Наивный алгоритм слияния двоичной кучи объединит две кучи и во время просто объединив обе кучи и сделав кучу из полученного массива, используя Алгоритм Флойда для строительства кучи. В качестве альтернативы, кучи можно просто объединить, последовательно вставив каждый элемент в , не торопясь .

Мешок и Стрототт предложил алгоритм объединения двоичных куч в время.[3] Известно, что их алгоритм более эффективен, чем второе наивное решение, описанное выше, примерно когда . Слияние теней работает асимптотически лучше, чем их алгоритм, даже в худшем случае.

Есть несколько других куч, которые поддерживают более быстрое время слияния. Например, Куча Фибоначчи можно объединить время. Поскольку двоичные кучи требуют время сливаться,[4] слияние теней остается эффективным.

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

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