Реализация запроса в дереве отрезков снизу — различия между версиями

Материал из Викиконспекты
Перейти к: навигация, поиск
Строка 24: Строка 24:
 
             result = min(result, data[left]);
 
             result = min(result, data[left]);
 
         return result;
 
         return result;
 +
 +
==Ссылки==
 +
 +
[http://e-maxx.ru/algo/segment_tree - MAXimal :: algo :: Дерево отрезков]
 +
 +
[http://ru.wikipedia.org/wiki/%D0%94%D0%B5%D1%80%D0%B5%D0%B2%D0%BE_%D0%BE%D1%82%D1%80%D0%B5%D0%B7%D0%BA%D0%BE%D0%B2  - Дерево отрезков — Википедия]

Версия 21:45, 8 мая 2011

Описание

Реализация запроса снизу вверх в дереве отрезков является, в отличие от реализации сверху вниз, итеративным методом.

Алгоритм

Реализация запроса снизу вверх

Будем рассматривать дерево отрезков с операцией нахождения минимального значения на отрезке(RMQ).
Если левая граница является правым сыном, то отрезаем ее и аналогично рассматриваем правую границу (является ли правая граница левым сыном). Затем поднимаемся к родителям новых границ. Отрезая границу, мы считаем минимум из отрезанного значения и минимума на оставшемся отрезке.

Псевдокод

Псевдокод функции нахождения минимума на отрезке [math][left, right][/math].

  segmentMin(left, right)
     res = MAX_INT; 
     while left < right
        if left == <правый сын>
           res = min(result, data[left]);
           left = <родитель правого соседа>;
        else
           left = <родитель left'a>;
        if right == <левый сын>
           result = min(result, data[right]);
           right = <родитель левого соседа>;
        else
           right = <родитель right'a>;
        if left == right
           result = min(result, data[left]);
        return result;

Ссылки

- MAXimal :: algo :: Дерево отрезков

- Дерево отрезков — Википедия