Реализация запроса в дереве отрезков снизу — различия между версиями
Gemin (обсуждение | вклад) (→Псевдокод) |
Gemin (обсуждение | вклад) (→Псевдокод) |
||
Строка 26: | Строка 26: | ||
return result; | return result; | ||
− | Функция <tex>parent()</tex> возвращает родителя аргумента. | + | Функция <tex>parent()</tex> возвращает родителя аргумента.<br> |
Функции <tex>isLeftSon(), isRightSon()</tex> возвращают является ли элемент правым или левым сыном соответственно. | Функции <tex>isLeftSon(), isRightSon()</tex> возвращают является ли элемент правым или левым сыном соответственно. | ||
Пусть дерево отрезков реализовано на массиве с индексацией элементов с 1. | Пусть дерево отрезков реализовано на массиве с индексацией элементов с 1. |
Версия 04:39, 18 мая 2011
Содержание
Описание
Реализация запроса снизу вверх в дереве отрезков является, в отличие от реализации сверху вниз, итеративным методом.
Алгоритм
Будем рассматривать дерево отрезков с операцией нахождения минимального значения на отрезке(RMQ).
Установим границы отрезка на соответствующие листья. Если элемент попавший на левую границу является правым сыном, то отрезаем его, левая граница перемещается на один элемент вправо; в другом случае левую границу не трогаем. Аналогично рассматриваем элемент попавший на правую границу (является ли этот элемент левым сыном). Затем устанавливаем границы отрезка на родительские элементы текущих границ. Отрезая элемент, мы считаем минимум из отрезанного и минимума на оставшемся отрезке. Закончим алгоритм, когда границы пересекутся.
Псевдокод
Псевдокод функции нахождения минимума на отрезке
.segmentMin(left, right) res = MAX_INT; while left < right if isRightSon(left) res = min(result, data[left]); left = parent(left + 1); else left = parent(left); if isLeftSon(right) result = min(result, data[right]); right = parent(right - 1); else right = parent(right); if left == right result = min(result, data[left]); return result;
Функция
Функции возвращают является ли элемент правым или левым сыном соответственно.
Пусть дерево отрезков реализовано на массиве с индексацией элементов с 1.
parent(vertex) return vertex / 2;
isLeftSon(vertex) if parent(vertex) * 2 + 1 == vertex return true; return false;