Статистики на отрезках. Корневая эвристика
Определение
Корневая эвристика (Sqrt-декомпозиция) — это метод, или структура данных, которая позволяет выполнять некоторые типичные операции (суммирование элементов подмассива, нахождение минимума/максимума и т.д.) за .
Описание
Привидем описание для операции минимума
Дан массив . Cделаем следующий предпосчёт: разделим массив A на блоки длины (округлённому к целому), и в каждом блоке заранее предпосчитаем нужную операцию в нём. Пусть len — это длина блока , а — количество блоков:
Через мы обозначили результат предпосчёта в k-ом подотрезке.
Для того чтобы минимум на отрезке , надо найти минимум среди элементов "хвостов": и , и минимума среди во всех блоках, начиная с k и заканчивая p:
Теперь разрешим изменять элементы. Если меняется какой-то элемент , то достаточно пересчитать значение в том блоке, в котором этот элемент находится:
, где - элементы блока b_k</tex>
Оценка сложности
Размер каждого из "хвостов", очевидно, не превосходит длины блока , а количество блоков не превосходит . Поскольку и , и мы выбирали , то всего для вычисления суммы в отрезке нам понадобится операций.