WikiDer > Кинетическая куча

Kinetic heap
Kinetic Heap overview.png

А Кинетическая куча это кинетическая структура данных, полученные кинетизация из куча. Он предназначен для хранения элементов (ключей, связанных с приоритетами), приоритет которых изменяется как непрерывная функция времени. Как вид очередь с кинетическим приоритетом, он поддерживает сохраненный в нем элемент максимального приоритета. Структура данных кинетической кучи работает, сохраняя элементы в виде дерева, которое удовлетворяет следующему свойству кучи - если B это дочерний узел из А, то приоритет элемента в А должен быть выше, чем приоритет элемента в B. Это свойство кучи обеспечивается с помощью сертификаты вдоль каждого края, поэтому, как и другие кинетические структуры данных, кинетическая куча также содержит очередь приоритетов (очередь событий) для поддержания времени отказа сертификата.

Реализация и операции

Обычную кучу можно кинетизировать, дополнив сертификатом [А>B] для каждой пары узловА, B такой, что B является дочерним узлом А. Если значение, хранящееся в узле Икс это функция жИкс(т) времени, то этот сертификат действителен только пока жА(т)> fB(т). Таким образом, отказ этого сертификата должен быть запланирован в очереди событий единовременно. т такой, что жА(т)> fB(т).

Все сбои сертификатов планируются в «очереди событий», которая считается эффективной приоритетной очередью, операции которой занимают O (журнал п) время.

Работа с ошибками сертификатов

Кинетическая куча swap.png

Когда сертификат [А>B] не выполняется, структура данных должна поменяться местами А и B в куче и обновите сертификаты, в которых был каждый из них.

Например, если (назовите его дочерние узлы ) был дочерним узлом (назовите его дочерние узлы и это родительский узел ), и сертификат [А>B] не работает, тогда структура данных должна поменяться местами и , затем замените старые сертификаты (и соответствующие запланированные события) [А>B], [А<Икс], [А>C], [B>Y], [B>Z] с новыми сертификатами [B>А], [B<Икс], [B>C], [А>Y] и [А>Z].

Таким образом, полагая невырожденность событий (никакие два события не происходят одновременно), только постоянное количество событий нужно отменить и перенести даже в худшем случае.

Операции

Кинетическая куча поддерживает следующие операции:

  • создать кучу(час): создать пустую кинетическую кучу час
  • find-max(ч, т) (или же find-min): - вернуть Максимум (или же мин для мин-куча) значение, хранящееся в куче час в текущее виртуальное время т.
  • вставлять(Икс, fИкс, т): - вставьте ключ Икс в кинетическую кучу в текущее виртуальное время т, значение которой изменяется как непрерывная функция жИкс(т) времени т. Прошивка производится как в обычной куче в O (журнал п) время, но O (журнал п) в результате может потребоваться изменение сертификатов, поэтому общее время переноса сбоев сертификатов составляет O (журнал 2 п)
  • Удалить(Икс, т) - удалить ключ Икс в текущее виртуальное время т. Удаление выполняется как в обычной куче в O (журнал п) время, но O (журнал п) в результате может потребоваться изменение сертификатов, поэтому общее время переноса сбоев сертификатов составляет O (журнал 2 п).

Спектакль

Кинетические кучи хорошо работают по четырем параметрам (ответная реакция, местонахождение, компактность и эффективность) качества кинетической структуры данных, определенного Basch et al.[1] Анализ первых трех качеств прост:

  • Ответная реакция: Кинетическая куча реагирует на запросы, поскольку каждый сбой сертификата вызывает замену соответствующих ключей и приводит к замене лишь нескольких сертификатов в худшем случае.
  • Местонахождение: Каждый узел присутствует в одном сертификате каждый вместе со своим родительским узлом и двумя дочерними узлами (если они есть), что означает, что каждый узел может быть задействован в общей сложности в трех запланированных событиях в худшем случае, таким образом, кинетические кучи являются локальными.
  • Компактность: Каждое ребро в куче соответствует ровно одному запланированному событию, поэтому количество запланированных событий точно равно п-1 куда п - количество узлов в кинетической куче. Таким образом, кинетические отвалы компактны.

Анализ эффективности

Эффективность кинетической кучи в общем случае практически неизвестна.[1][2][3] Однако в частном случае аффинное движение f (т) = ат + b Из приоритетов кинетические кучи, как известно, очень эффективны.[2]

Аффинное движение, без вставок и удалений

В этом особом случае можно показать, что максимальное количество событий, обрабатываемых кинетической кучей, в точности равно количеству ребер в переходное закрытие древовидной структуры кучи, которая O (пбревноп) для дерева высотой O (журналп).[2]

Аффинное движение со вставками и удалениями

Если п вставки и удаления выполняются в кинетической куче, которая начинается пустой, максимальное количество обрабатываемых событий [4] Однако эта граница не считается жесткой,[2] и единственная известная нижняя граница .[4]

Варианты

В этой статье рассматриваются "простые" кинетические кучи, как описано выше, но для специализированных приложений были разработаны другие варианты,[5] Такие как:

Другие кинетические очереди приоритетов типа кучи:

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

  1. ^ а б Basch, J., Guibas, L.J., Hershberger, J (1997). «Структуры данных для мобильных данных». Материалы восьмого ежегодного симпозиума ACM-SIAM по дискретным алгоритмам. СОДА. Общество промышленной и прикладной математики. стр. 747–756. Получено 17 мая, 2012.CS1 maint: несколько имен: список авторов (связь)
  2. ^ а б c d да Фонсека; Guilherme D .; де Фигейредо; Селина М. Х. «Кинетические деревья с упорядочением в куче: точный анализ и улучшенные алгоритмы» (PDF). Письма об обработке информации. С. 165–169. Архивировано из оригинал (PDF) 24 мая 2015 г.. Получено 17 мая, 2012.
  3. ^ да Фонсека, Гильерме Д. и де Фигейредо, Селина М. Х. и Карвалью, Пауло К. П. «Кинетическая вешалка» (PDF). Письма об обработке информации. С. 151–157. Архивировано из оригинал (PDF) 24 мая 2015 г.. Получено 17 мая, 2012.CS1 maint: несколько имен: список авторов (связь)
  4. ^ а б Basch, J, Guibas, L.J., Ramkumar, G.D. (1997). «Широкие линии и отрезки с кучей». Материалы тринадцатого ежегодного симпозиума по вычислительной геометрии. SCG. ACM. стр. 469–471. Получено 17 мая, 2012.CS1 maint: несколько имен: список авторов (связь)
  5. ^ К. Х., Тарьян Р. и Т. К. (2001). «Более быстрые кинетические кучи и их использование при планировании трансляций» (PDF). Proc. 12-й симпозиум ACM-SIAM по дискретным алгоритмам. ACM. стр. 836–844. Получено 17 мая, 2012.CS1 maint: несколько имен: список авторов (связь)[постоянная мертвая ссылка]

Гибас, Леонид. «Кинетические структуры данных - Справочник» (PDF). Архивировано из оригинал (PDF) на 2007-04-18. Получено 17 мая, 2012.