Сведение задачи LCA к задаче RMQ — различия между версиями
(→Препроцессинг: naming and formatting) |
(→Алгоритм: preprocessing explanation and simple expression of lcd) |
||
Строка 14: | Строка 14: | ||
Ясно, что глубина вершины элементарным образом поддерживается во время обхода в глубину. | Ясно, что глубина вершины элементарным образом поддерживается во время обхода в глубину. | ||
− | Запустим [[Обход в глубину, цвета вершин|обход в глубину]] из корня, который будет | + | Запустим [[Обход в глубину, цвета вершин|обход в глубину]] из корня, который будет вычислять значения следующих величин: |
+ | #Cписок глубин посещенных вершин <tex>d</tex>. Глубина текущей вершины добавляется в конец списка при входе в данную вершину, а также после каждого возвращения из её сына. | ||
+ | #Список посещений узлов <tex>vtx</tex>, строящийся аналогично предыдущему, только добавляется не глубина а сама вершина. | ||
+ | #Значение функции <tex>I[u]</tex>, возвращающей любой индекс в списке глубин <tex>d</tex>, по которому была записана глубина вершины <tex>u</tex> (например при входе в вершину). | ||
=== Запрос === | === Запрос === | ||
− | + | Будем считать, что <tex>\mathrm{rmq}(d, l, r)</tex> возвращает индекс минимального элемента в <tex>d</tex> на отрезке <tex>[l..r]</tex>. Тогда ответом на запрос <tex>\mathrm{lca}(u, v)</tex> будет <tex>\mathrm{vtx}[\mathrm{rmq}(d, I[u], I[v])]</tex>. | |
− | |||
=== Доказательство корректности алгоритма === | === Доказательство корректности алгоритма === |
Версия 19:54, 12 июня 2012
Содержание
Постановка задачи LCA
Определение: |
Наименьшим общим предком (least common ancestor) двух узлов | и в корневом дереве называется узел , который среди всех узлов, являющихся предками как узла , так и , имеет наибольшую глубину.
Пусть дано корневое дерево
. На вход подаются запросы вида , для каждого запроса требуется найти их наименьшего общего предка.Алгоритм
Препроцессинг
Для каждой вершины
определим глубину вершину с помощью следующей рекурсивной формулы:Ясно, что глубина вершины элементарным образом поддерживается во время обхода в глубину.
Запустим обход в глубину из корня, который будет вычислять значения следующих величин:
- Cписок глубин посещенных вершин . Глубина текущей вершины добавляется в конец списка при входе в данную вершину, а также после каждого возвращения из её сына.
- Список посещений узлов , строящийся аналогично предыдущему, только добавляется не глубина а сама вершина.
- Значение функции , возвращающей любой индекс в списке глубин , по которому была записана глубина вершины (например при входе в вершину).
Запрос
Будем считать, что
возвращает индекс минимального элемента в на отрезке . Тогда ответом на запрос будет .Доказательство корректности алгоритма
Теорема: |
Наименьшему общему предку вершин соответствует минимальная глубина на отрезке . |
Доказательство: |
Рассмотрим два узла | корневого дерева . Рассмотрим отрезок . Поскольку этот отрезок — путь из в , он проходит через их наименьшего общего предка (в дереве есть только один простой путь между вершинами). Покажем, что его глубина минимальна на отрезке . Допустим обратное. Все потомки имеют глубину больше. Но тогда получим, что поиск в глубину вышел из поддерева вершины раньше, чем посетил вершину .
Пример
Рассмотрим дерево на рисунке 1. Найдем наименьшего общего предка вершин, помеченных красным цветом. Список глубин, получающийся в результате обхода в глубину -
Глубина наименьшего общего предка красных вершин равна минимуму на отрезкеСложность
Для нахождения минимального элемента на отрезке можно использовать дерево отрезков. Длина массива глубин будет равна , т. е. дерево отрезков можно построить за Таким образом, препроцессинг работает за Время выполнения запроса равно времени запроса минимального элемента на отрезке в дереве отрезков, т. е.
См.также
- Метод двоичного подъема
- Решение RMQ с помощью разреженной таблицы
- Алгоритм Фарака-Колтона и Бендера
- Сведение задачи RMQ к задаче LCA