Сведение задачи RMQ к задаче LCA — различия между версиями
Строка 3: | Строка 3: | ||
== Алгоритм == | == Алгоритм == | ||
Декартово дерево(Сartesian tree) на массиве <tex>A[1..N]</tex> - это бинарное дерево, рекурсивно определенное следующим образом: | Декартово дерево(Сartesian tree) на массиве <tex>A[1..N]</tex> - это бинарное дерево, рекурсивно определенное следующим образом: | ||
− | * | + | * Корнем дерева является минимальное значение в массиве <tex>A</tex>, скажем <tex>A[i]</tex>. |
− | * | + | * Левым поддеревом является декартово дерево на массиве <tex>A[1..i-1]</tex>. |
− | * | + | * Правым поддеревом является декартово дерево на массиве <tex>A[i+1..N]</tex>. |
Построим декартово дерево на массиве <tex>A</tex>. Тогда <tex>RMQ(i, j)</tex> = <tex>LCA(A[i], A[j])</tex>. | Построим декартово дерево на массиве <tex>A</tex>. Тогда <tex>RMQ(i, j)</tex> = <tex>LCA(A[i], A[j])</tex>. | ||
== Доказательство == | == Доказательство == |
Версия 06:29, 6 мая 2011
Постановка задачи RMQ
Дан массив
. Поступают запросы вида , на каждый запрос требуется найти минимум в массиве , начиная с позиции и заканчивая позицией .Алгоритм
Декартово дерево(Сartesian tree) на массиве
- это бинарное дерево, рекурсивно определенное следующим образом:- Корнем дерева является минимальное значение в массиве , скажем .
- Левым поддеревом является декартово дерево на массиве .
- Правым поддеревом является декартово дерево на массиве .
Построим декартово дерево на массиве
. Тогда = .Доказательство
Мы знаем что:
- 1. Любая вершина дерева всегда имеет меньшее значение, чем её дети. Тогда любой предок или меньше их самих.
- 2. Все вершины, которые лежат в дереве на пути от до , а так же их поддеревья образуют подмассив (возьмём только правое поддерево у и левое поддерево у ). Т.к. всё, что левее -го элемента в массиве, лежит левее в дереве, и всё, что правее -го, лежит правее . A дерево содержит все элементы .
- 3. Из всех вершин, определенных в п.2, ближайший к корню и по п.1 имеет наименьшее значение в подмассиве .
Сложность
Построение дерева наивным алгоритмом
. Существует алгоритм построение за . Препроцессинг для - и ответ на запрос . В итоге получили {построение , запрос }.