Сведение задачи RMQ к задаче LCA — различия между версиями
(→Описание) |
(→Описание) |
||
Строка 5: | Строка 5: | ||
== Алгоритм == | == Алгоритм == | ||
===Описание=== | ===Описание=== | ||
− | [[Файл:Wiki.PNG|thumb|right| | + | [[Файл:Wiki.PNG|thumb|right|400x200px|Пример декартового дерева]] |
Будем решать задачу RMQ, уже умея решать задачу LCA. Для хранения решения задачи о LCA будем использовать [[декартово дерево по неявному ключу]]. Тогда минимум на отрезке от <tex> i </tex> до <tex> j </tex> будет равен наименьшему общему предку <tex>i</tex>-того и <tex>j</tex>-того элементов из декартова дерева. | Будем решать задачу RMQ, уже умея решать задачу LCA. Для хранения решения задачи о LCA будем использовать [[декартово дерево по неявному ключу]]. Тогда минимум на отрезке от <tex> i </tex> до <tex> j </tex> будет равен наименьшему общему предку <tex>i</tex>-того и <tex>j</tex>-того элементов из декартова дерева. | ||
Версия 10:24, 9 июня 2015
Задача: |
Дан массив | . Поступают запросы вида , на каждый запрос требуется найти минимум в массиве , начиная с позиции и заканчивая позицией .
Алгоритм
Описание
Будем решать задачу RMQ, уже умея решать задачу LCA. Для хранения решения задачи о LCA будем использовать декартово дерево по неявному ключу. Тогда минимум на отрезке от до будет равен наименьшему общему предку -того и -того элементов из декартова дерева.
Декартово дерево по неявному ключу на массиве — это бинарное дерево, допускающее следующее рекурсивное построение:
- Корнем дерева является элемент массива, имеющий минимальное значение , скажем . Если минимальных элементов несколько, можно взять любой.
- Левым поддеревом является декартово дерево на массиве .
- Правым поддеревом является декартово дерево на массиве .
Здесь и далее
будет также использоваться для обозначения соответствующей вершины дерева.Построим декартово дерево на массиве
Корректность
Теорема: |
= . |
Доказательство: |
Положим .Заметим, что и не принадлежат одновременно либо правому, либо левому поддереву , потому как тогда бы соответствующий сын находился на большей глубине, чем , и также являлся предком как так и , что противоречит определению . Из этого замечанию следует, что лежит между и и, следовательно, принадлежит отрезку .
|
Сложность
Существует алгоритм, который строит декартово дерево за . Используя алгоритм построения LCA, получаем: препроцессинг для — и ответ на запрос — .
Нам нужно единожды построить декартово дерево за
, единожды провести препроцессинг за и отвечать на запросы за .В итоге получили
с построением за и ответом на запрос за .