Декартово дерево
Эта статья про Курево
Декартово дерево — это структура данных, объединяющая в себе бинарное дерево поиска и бинарную кучу (отсюда и второе её название: и дерамида (дерево+пирамида).
Более строго, это структура данных, которая хранит пары в виде бинарного дерева таким образом, что она является бинарным деревом поиска по и бинарной пирамидой по . Предполагая, что все и все являются различными, получаем, что если некоторый элемент дерева содержит , то всех элементов в левом поддереве , у всех элементов в правом поддереве , а также и в левом, и в правом поддереве имеем: .
Дерамиды были предложены Сиделем (Siedel) и Арагоном (Aragon) в 1996 г.
Содержание
Операция split
Тут будет split
Операция merge
А тут будет merge
Операция add
Операция добавляет в дерево элемент , где — ключ, а — приоритет.
Реализация №1:
- Разбиваем наше дерево по ключу, который мы хотим добавить, то есть .
- Сливаем первое дерево с новым элементом, то есть .
- Сливаем получившиеся дерево со вторым, то есть .
Реализация №2:
Сначала спускаемся по дереву (как в обычном бинарном дереве поиска по ), но останавливаемся на первом элементе, в котором значение приоритета оказалось меньше . Мы нашли позицию, куда будем вставлять наш элемент. Теперь вызываем от найденного элемента (от элемента вместе со всем его поддеревом), и возвращаемые ею и записываем в качестве левого и правого сына добавляемого элемента.
Операция remove
Операция удаляет из дерева элемент с ключом .
Реализация №1:
- Разбиваем наше дерево по ключу, который мы хотим удалить, то есть .
- Теперь отделяем от второго дерева элемент , опять таки разбивая по ключу , то есть .
- Сливаем первое дерево со третьим, то есть .
Реализация №2:
Спускаемся по дереву (как в обычном бинарном дереве поиска по ), ища удаляемый элемент. Найдя элемент, мы просто вызываем его левого и правого сыновей, и возвращаемое ею значение ставим на место удаляемого элемента, то есть .