Это не официальный сайт wikipedia.org 01.01.2023

Сливаемая куча — Википедия

Сливаемая куча

Сливаемая куча (англ. Mergeable heap) — структура данных, которая поддерживает следующие пять операций:

  • Создание пустой кучи H (англ. Make heap);
  • Вставка узла x в кучу H (англ. Insert);
  • Поиск узла в куче H , который обладает минимальным ключом (англ. Minimum);
  • Удаление узла с минимальным ключом из кучи H (англ. Extract minimum);
  • Создание новой кучи H , которая содержит все узлы куч H 1 и H 2 (англ. Union).

РеализацииПравить

Следующие две структуры данных являются реализациями сливаемой кучи:

Эти структуры данных так же поддерживают еще 2 операции:

  • Присваивание узлу x   в куче H   нового значения ключа (англ. Decrease key) (предполагается, что новое значение ключа не превосходит текущего);
  • Удаление узла x   из кучи H   (англ. Delete).


Время выполнения операций у разных реализаций сливаемых пирамид
Операция Биномиальная куча Фибоначчиева куча
Make heap Θ(1) Θ(1)
Insert O(lgn) Θ(1)
Minimum O(lgn) Θ(1)
Extract minimum Θ(lgn) O(lgn)
Union Ω(lgn) Θ(1)
Decrease key Θ(lgn) Θ(1)
Delete Θ(lgn) O(lgn)

Примечание: для Биномиальной кучи время в наихудшем случае, для Фибоначчиевой кучи амортизированное время.


Замечание. По умолчанию сливаемые кучи являются неубывающими сливаемыми кучами (англ. Mergeable min-heap). Также существуют невозрастающие сливаемые кучи (англ. Mergeable max-heap), которые поддерживают следующие операции:

  • Создание пустой кучи H   (англ. Make heap);
  • Вставка узла x   в кучу H   (англ. Insert);
  • Поиск узла в куче H  , который обладает максимальныи ключом (англ. Maximum);
  • Удаление узла с максимальныи ключом из кучи H   (англ. Extract maximum);
  • Создание новой кучи H  , которая содержит все узлы куч H 1   и H 2   (англ. Union).
  • Присваивание узлу x   в куче H   нового значения ключа (англ. Increase key);
  • Удаление узла x   из кучи H   (англ. Delete).

ЛитератураПравить