Блог пользователя DmitriyH

Автор DmitriyH, 11 лет назад, По-русски

Возможно ли реализовать универсальное дерево отрезков (или другую структуру данных), которое поддерживает модификацию на интервале и запрос на интервале?

Под универсальным, подразумевается реализация в виде шаблона, у которого функция «комбинирования значений» (F1) и функция «комбинирования модификаций» (F2) являются параметрами шаблона.
Например:

1) (запрос минимума/присвоение на отрезке): F1 = min, F2 = assign
2) (запрос XOR-a/прибавление на отрезка): F1 = XOR, F2 = add

С более частными случаями ((обновление значения/запрос отрезка), (обновление отрезка/запрос значения)) обобщенная реализация, вроде, получается, но (обновление отрезка/запрос отрезка) — ни в какую. И что-то мне подсказывает, что либо это невозможно, либо F1 и F2 должны обладать какими-то дополнительными свойствами, либо нужная еще какая-нибудь функция F3..

Другими словами: если это возможно, то как? и если нет, то какими дополнительными свойствами должны обладать F1 и F2, чтобы это было возможно?

Бонус-вопрос: правильно ли я понимаю, что дерево (инвертирование однобитных чисел на интервале и запрос суммы) в 242E - XOR на отрезке также использует особые свойства этих функций и не подлежит обобщению?

Спасибо заранее!

  • Проголосовать: нравится
  • +6
  • Проголосовать: не нравится

»
11 лет назад, # |
  Проголосовать: нравится +3 Проголосовать: не нравится

У меня есть шаблон, который вам, возможно, поможет. http://ideone.com/C6CKTH И возможный вариант использования http://ideone.com/T4HPZJ. Для поиска максимума на отрезке, и добавления числа к отрезку.

»
11 лет назад, # |
  Проголосовать: нравится +3 Проголосовать: не нравится

Я недавно писал такое дерево, только потом отложилось. Уже не помню к чему я пришёл. Постараюсь в ближайшее время дописать и выложить код.

»
11 лет назад, # |
Rev. 4   Проголосовать: нравится +8 Проголосовать: не нравится

Эхх, а ведь это одно из домашних заданий в первом семестре на ФИВТ МФТИ)

Как минимум 3 метода придётся передавать в параметр шаблона:

1) Объединение 2 значений

2) Объединение 2 модификаций

3) Применение модификации к значению в вершине дерева

Вот пример реализации такого класса: https://code.google.com/p/fivt2013-advanced-a/source/browse/Zhuravlyov/Task3_SegmentTree/advancedTree.h

В той же папке можно посмотреть пример реализации конкретного дерева на основе универсального. В частности решены задачи с максимальной подсуммой и количеством отрезков постоянности