Jump to content

Объединяемая куча

В информатике ( объединяемая куча также называемая объединяемой кучей ) — это абстрактный тип данных , который представляет собой кучу, поддерживающую операцию слияния.

Определение

[ редактировать ]

Объединяемая куча поддерживает обычные операции с кучей: [1]

  • Make-Heap(), создайте пустую кучу.
  • Insert(H,x), вставьте элемент x в кучу H.
  • Min(H), верните минимальный элемент или Nil если такого элемента не существует.
  • Extract-Min(H), извлеките и верните минимальный элемент или Nil если такого элемента не существует.

И еще одно, что его отличает: [1]

  • Merge(H1,H2), объединить элементы H1 и H2 в одну кучу.

Тривиальная реализация

[ редактировать ]

Реализовать объединяемую кучу при наличии простой кучи несложно:

Merge(H1,H2):

  1. x ← Extract-Min(H2)
  2. while x ≠ Nil
    1. Insert(H1, x)
    2. x ← Extract-Min(H2)

Однако это может быть расточительно, поскольку каждый Extract-Min(H) и Insert(H,x) обычно приходится поддерживать свойство кучи .

Более эффективные реализации

[ редактировать ]

Примеры объединяемых структур данных кучи включают в себя:

Более полный список со сравнением производительности можно найти в Heap (структура данных) § Сравнение теоретических границ вариантов .

В большинстве объединяемых структур кучи слияние является фундаментальной операцией, на которой основаны другие. Вставка реализуется путем объединения новой одноэлементной кучи с существующей кучей. Удаление реализуется путем слияния дочерних элементов удаляемого узла.

См. также

[ редактировать ]
  1. ^ Jump up to: а б Кормен, Томас Х .; Лейзерсон, Чарльз Э .; Ривест, Рональд Л .; Стоун, Клиффорд (2009) [1990]. Введение в алгоритмы (3-е изд.). MIT Press и McGraw-Hill. стр. 505–506. ISBN  0-262-03384-4 .
Arc.Ask3.Ru: конец переведенного документа.
Arc.Ask3.Ru
Номер скриншота №: 96f327dd225e77e0624705bfcb0a9fd0__1715614500
URL1:https://arc.ask3.ru/arc/aa/96/d0/96f327dd225e77e0624705bfcb0a9fd0.html
Заголовок, (Title) документа по адресу, URL1:
Mergeable heap - Wikipedia
Данный printscreen веб страницы (снимок веб страницы, скриншот веб страницы), визуально-программная копия документа расположенного по адресу URL1 и сохраненная в файл, имеет: квалифицированную, усовершенствованную (подтверждены: метки времени, валидность сертификата), открепленную ЭЦП (приложена к данному файлу), что может быть использовано для подтверждения содержания и факта существования документа в этот момент времени. Права на данный скриншот принадлежат администрации Ask3.ru, использование в качестве доказательства только с письменного разрешения правообладателя скриншота. Администрация Ask3.ru не несет ответственности за информацию размещенную на данном скриншоте. Права на прочие зарегистрированные элементы любого права, изображенные на снимках принадлежат их владельцам. Качество перевода предоставляется как есть. Любые претензии, иски не могут быть предъявлены. Если вы не согласны с любым пунктом перечисленным выше, вы не можете использовать данный сайт и информация размещенную на нем (сайте/странице), немедленно покиньте данный сайт. В случае нарушения любого пункта перечисленного выше, штраф 55! (Пятьдесят пять факториал, Денежную единицу (имеющую самостоятельную стоимость) можете выбрать самостоятельно, выплаичвается товарами в течение 7 дней с момента нарушения.)