Разложение тяжелого пути - Heavy path decomposition

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

Разложение на дорожки

Если края дерева Т разделены на набор тяжелых ребер и легких ребер, причем по одному тяжелому ребру от каждого нелистового узла к одному из его дочерних элементов, тогда подграф, образованный тяжелыми ребрами, состоит из набора путей, причем каждая нелистовая вершина принадлежит ровно на один путь, содержащий его тяжелый край. Конечные узлы дерева, которые не являются конечной точкой тяжелого ребра, можно рассматривать как образующие пути нулевой длины. Таким образом, каждая вершина принадлежит ровно одному из путей. Каждый путь имеет головную вершину, самую верхнюю вершину.

В качестве альтернативы пути с толстыми краями могут быть расширены путем включения одного светлого края, от начала пути до его родителя.[1] В этом варианте разложения некоторые вершины принадлежат нескольким путям, но каждое ребро Т принадлежит ровно одному пути.

Дерево путей

Сами пути разложения могут быть организованы в дерево, называемое «дерево путей», «дерево тяжелых путей» или «сжатое дерево». Каждый узел дерева путей соответствует пути декомпозиции тяжелого пути. Если п является путем разложения тяжелого пути, то родитель п в дереве путей - это путь, содержащий родительский элемент заголовка п. Корень дерева путей - это путь, содержащий корень исходного дерева. В качестве альтернативы, дерево путей может быть сформировано из исходного дерева с помощью сжатие края всех тяжелых краев.

«Легкое» ребро данного дерева - это ребро, которое не было выбрано при декомпозиции тяжелого пути. Если светлое ребро соединяет два узла дерева Икс и у, с Икс родитель у, тогда Икс должен иметь как минимум вдвое больше потомков, чем у. Следовательно, на любом пути от корня к листу дерева с п узлов, может быть не более журнала2 п светлые края. Эквивалентно дерево путей имеет высоту не более log2 п.

Приложения

Разложение тяжелого пути было введено Слейтор и Тарьян (1983) как часть амортизированный анализ от их связать / вырезать дерево структура,[2] и по Харел и Тарджан (1984) как часть их структура данных за самые низкие общие предки,[3] Структура данных дерева ссылок / разрезов использует разделение динамического дерева на пути, которое не обязательно является разложением по тяжелому пути; его анализ использует потенциальная функция измерение его расстояния от разложения тяжелого пути, а небольшая высота дерева путей подразумевает, что каждая операция структуры данных выполняет только небольшое количество шагов, которые не могут быть оплачены улучшением этой функции.[2] В структуре данных самого низкого общего предка декомпозиция используется для встраивания входного дерева в полное двоичное дерево логарифмической глубины, что позволяет решать каждый запрос за постоянное время побитовые операции.[3]

Последующие применения декомпозиции тяжелого пути включали решение проблема предка уровня,[4] вычисление редактировать расстояние между деревьями,[5][6] рисунок графика и жадное вложение,[7][8][9] поиск пути около всех узлов данного графа,[10] диагностика неисправностей в волоконно-оптическая связь сети,[1] и расшифровка грамматические коды,[11] среди прочего.

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

  1. ^ а б Харви, Николас Дж. А .; Пэтрашку, Михай; Вен, Юнган; Еханин, Сергей; Чан, Винсент В. С. (2007), «Неадаптивная диагностика неисправностей для полностью оптических сетей с помощью комбинаторного группового тестирования на графах», 26-я Международная конференция IEEE по компьютерным коммуникациям (ИНФОКОМ 2007), стр. 697–705, Дои:10.1109 / INFCOM.2007.87.
  2. ^ а б Слейтор, Дэниел Д.; Тарджан, Роберт Эндре (1983), «Структура данных для динамических деревьев», Журнал компьютерных и системных наук, 26 (3): 362–391, Дои:10.1016/0022-0000(83)90006-5, МИСТЕР  0710253.
  3. ^ а б Харел, Дов; Тарджан, Роберт Э. (1984), «Быстрые алгоритмы поиска ближайших общих предков», SIAM Журнал по вычислениям, 13 (2): 338–355, Дои:10.1137/0213024.
  4. ^ Дитц, Пол Ф. (1991), "Поиск предков уровня в динамических деревьях", Алгоритмы и структуры данных (Оттава, Онтарио, 1991), Конспект лекций по информатике, 519, Берлин: Springer, стр. 32–40, Дои:10.1007 / BFb0028247, МИСТЕР  1146687.
  5. ^ Кляйн, Филип Н. (1998), "Вычисление расстояния редактирования между упорядоченными деревьями без корня", Алгоритмы - ESA '98 (Венеция), Конспект лекций по информатике, 1461, Берлин: Springer, стр. 91–102, Дои:10.1007/3-540-68530-8_8, МИСТЕР  1683332.
  6. ^ Демейн, Эрик Д.; Мозес, Шей; Россман, Бенджамин; Вейманн, Орен (2010), "Оптимальный алгоритм разложения для расстояния редактирования дерева", ACM-транзакции на алгоритмах, 6 (1): A2, Дои:10.1007/978-3-540-73420-8_15, МИСТЕР  2654906.
  7. ^ Buchsbaum, Adam L .; Уэстбрук, Джеффри Р. (2000), «Поддержание иерархических представлений графов», Материалы одиннадцатого ежегодного симпозиума ACM-SIAM по дискретным алгоритмам (Сан-Франциско, Калифорния, 2000 г.), Нью-Йорк: ACM, стр. 566–575, МИСТЕР  1755515.
  8. ^ Эппштейн, Дэвид; Гудрич, Майкл Т. (2011), «Краткая жадная геометрическая трассировка с использованием гиперболической геометрии», Транзакции IEEE на компьютерах, 60 (11): 1571–1580, Дои:10.1109 / TC.2010.257, МИСТЕР  2830035.
  9. ^ Дункан, Кристиан А .; Эппштейн, Дэвид; Гудрич, Майкл Т.; Кобуров, Стивен Г .; Нелленбург, Мартин (2013), «Рисование деревьев с идеальным угловым разрешением и полиномиальной площадью», Дискретная и вычислительная геометрия, 49 (2): 157–182, arXiv:1009.0581, Дои:10.1007 / s00454-012-9472-у, МИСТЕР  3017904.
  10. ^ Альструп, Стивен; Лауридсен, Питер В; Зоммерлунд, Пер; Thorup, Mikkel (1997), "Поиск ядер ограниченной длины", Алгоритмы и структуры данных, Конспект лекций в томе информатики, 1272, Springer, стр. 45–54, Дои:10.1007/3-540-63307-3_47.
  11. ^ Билле, Филипп; Landau, Gad M .; Раман, Раджив; Садакане, Кунихико; Сатти, Шриниваса Рао; Вейманн, Орен (2011), "Произвольный доступ к строкам, сжатым грамматикой", Материалы двадцать второго ежегодного симпозиума ACM-SIAM по дискретным алгоритмам, Филадельфия, Пенсильвания: SIAM, стр. 373–389, МИСТЕР  2857133.