Куча Бродала-Окасаки — различия между версиями
Kirelagin (обсуждение | вклад) (→getMin: Нормальные обозначения) |
Kirelagin (обсуждение | вклад) (→extractMin: Нормальные обозначения и правильный код) |
||
Строка 56: | Строка 56: | ||
=== extractMin === | === extractMin === | ||
− | Минимальный элемент хранится в верхнем <tex> BPQ </tex>, | + | Минимальный элемент хранится в верхнем <tex> BPQ </tex>, поэтому его поиск не нужен. Требуется извлечение минимума из приоритетной очереди, состоящей из <tex> BPQ</tex>. |
<code> | <code> | ||
− | '''< | + | '''<int, BPQ>''' extractMin'('''<'''x:'''int''', q:'''PQ>'''): |
− | < | + | <<y, r>, t> = extractMin(q) |
− | '''return''' < | + | '''return''' <x, <y, merge(r, t)>> |
</code> | </code> | ||
− | Здесь <math>\mathrm{extractMin}</math>{{---}} это функция, извлекающая минимальный элемент типа <tex> BPQ </tex> из приоритетной очереди, она возвращает <tex> | + | Здесь <math>\mathrm{extractMin}</math> {{---}} это функция, извлекающая минимальный элемент типа <tex> BPQ </tex> из приоритетной очереди, она возвращает <tex>\langle y,r \rangle</tex> {{---}} минимальный элемент типа <tex> BPQ </tex> и остаток от приоритетной очереди после извлечение минимума {{---}} <tex>t</tex>. Соответственно, <math>\mathrm{merge}</math> {{---}} функция, выполняющая слияние двух приоритетных очередей. |
− | Возвращаем <tex> BPQ </tex>, где <tex> | + | Возвращаем минимум и <tex> BPQ </tex>, где <tex>x</tex> {{---}} новый минимальный элемент, и <math>\mathrm{merge}(r,t)</math> {{---}} приоритетная очередь без элементов <tex>x</tex> и <tex>y</tex>. |
− | Так как <math>\mathrm{extractMin}</math> и <math>\mathrm{merge}</math> выполняются за <tex>O(\log N)</tex>, | + | Так как <math>\mathrm{extractMin}</math> и <math>\mathrm{merge}</math> выполняются за <tex>O(\log N)</tex>, то <math>\mathrm{extractMin}</math> выполняется за <tex>O(\log N)</tex>. |
== Смотри также == | == Смотри также == |
Версия 18:25, 22 января 2015
Куча Бродала-Окасаки (англ. Brodal's and Okasaki's Priority Queue) — основана на использовании биномиальной кучи без каскадных ссылок, добавлении минимального элемента и на идеи Data-structural bootstrapping. Первое позволяет делать за , второе позволяет получать минимальный элемент за , а третье — позволяющей выполнить за . Удаление минимума работает за в худшем случае. Эти оценки являются асимптотически оптимальными среди всех основанных на сравнении приоритетных очередей.
Содержание
Структура
Используем идею, которую Тарьян и Буксбаум называют Data-structural bootstrapping.
Создадим структуру Bootstrapping Priority Queues, которая будет хранить пару из минимального элемента и приоритетную очередь. Элементами приоритетной очереди будут Bootstrapping Priority Queues упорядоченные по :
BPQ = <int, PQ(BPQ)>
Куча из одного элемента создается так:
BPQ singleton'(x:int): return <x, null>
Данная структура не будет бесконечной, так как каждый раз в приоритетной очереди будет храниться на один элемент меньше, таким образом образуя иерархическую структуру. Каждое значение храниться в одном из значений
Операции
Merge
Слияние выполняется выбором минимума из двух значений
BPQ merge'(<x:int, q:PQ>, <y:int, r:PQ>): if x < y return <x, insert(q, <y, r>)> else return <y, insert(r, <x, q>)>
Здесь
это добавление в приоритетную очередь. Если оно работает за , то работает за .Insert
Это создание нового
BPQ insert'(<x:int, q:PQ>, y:int): return merge'(<x, q>, singleton(y))
Создание и
выполняются за , тогда работает за .getMin
Выполняется просто, так как
int getMin'(<x:int, q:PQ>): return x
Очевидно, работает за
.extractMin
Минимальный элемент хранится в верхнем
<int, BPQ> extractMin'(<x:int, q:PQ>): <<y, r>, t> = extractMin(q) return <x, <y, merge(r, t)>>
Здесь
— это функция, извлекающая минимальный элемент типа из приоритетной очереди, она возвращает — минимальный элемент типа и остаток от приоритетной очереди после извлечение минимума — . Соответственно, — функция, выполняющая слияние двух приоритетных очередей.Возвращаем минимум и
, где — новый минимальный элемент, и — приоритетная очередь без элементов и .Так как
и выполняются за , то выполняется за .