WikiDer > Декартово дерево

Cartesian tree
Последовательность чисел и производное от них декартово дерево.

В Информатика, а Декартово дерево это двоичное дерево полученный из последовательности чисел; его можно однозначно определить из свойств, которые куча-заказано и что симметричный (по порядку) обход дерева возвращает исходную последовательность. Представлен Вюйлемен (1980) в контексте геометрического поиск диапазона структуры данных, Декартовы деревья также использовались в определении трогать и рандомизированное двоичное дерево поиска структуры данных для бинарный поиск проблемы. Декартово дерево для последовательности может быть построено в линейное время используя куча-основанный алгоритм поиска все ближайшие меньшие значения в последовательности.

Определение

Декартово дерево для последовательности различных чисел может быть однозначно определено следующими свойствами:

  1. Декартово дерево для последовательности имеет по одному узлу для каждого числа в последовательности. Каждый узел связан с одним значением последовательности.
  2. А симметричный (по порядку) обход дерева приводит к исходной последовательности. То есть левое поддерево состоит из значений, предшествующих корню в порядке следования, в то время как правое поддерево состоит из значений, более поздних, чем корень, и аналогичное ограничение порядка выполняется в каждом нижнем узле дерева.
  3. Дерево имеет куча собственности: родительский элемент любого некорневого узла имеет меньшее значение, чем сам узел.[1]

Основываясь на свойстве кучи, корень дерева должен быть наименьшим числом в последовательности. Исходя из этого, само дерево также может быть определено рекурсивно: корень - это минимальное значение последовательности, а левое и правое поддеревья - декартовы деревья для подпоследовательностей слева и справа от значения корня. Следовательно, три указанных выше свойства однозначно определяют декартово дерево.

Если последовательность чисел содержит повторения, декартово дерево может быть определено путем определения непротиворечивого правила разрыва связи (например, определения того, что первый из двух равных элементов рассматривается как меньший из двух) перед применением вышеуказанных правил.

Пример декартового дерева показан на рисунке выше.

Поиск по диапазону и наименьшие общие предки

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

Декартовы деревья могут использоваться как часть эффективного структура данных для минимальный диапазон запросов, а поиск диапазона проблема с запросами, которые запрашивают минимальное значение в непрерывной подпоследовательности исходной последовательности.[2] В декартовом дереве это минимальное значение может быть найдено в наименьший общий предок крайних левых и крайних правых значений в подпоследовательности. Например, в подпоследовательности (12,10,20,15) последовательности, показанной на первой иллюстрации, минимальное значение подпоследовательности (10) образует наименьшего общего предка крайнего левого и крайнего правого значений (12 и 15). Поскольку самые низкие общие предки могут быть найдены за постоянное время для каждого запроса, используя структуру данных, которая занимает линейное пространство для хранения и которая может быть построена за линейное время,[3] те же оценки справедливы и для задачи минимизации дальности.

Бендер и Фарач-Колтон (2000) изменил эту взаимосвязь между двумя проблемами структуры данных, показав, что самые низкие общие предки во входном дереве могут быть эффективно решены, применяя недревесную технику для минимизации диапазона. В их структуре данных используется Эйлер тур метод преобразования входного дерева в последовательность с последующим поиском минимумов диапазона в результирующей последовательности. Последовательность, полученная в результате этого преобразования, имеет особую форму (соседние числа, представляющие высоту соседних узлов в дереве, отличаются на ± 1), которой они пользуются в своей структуре данных; для решения задачи минимизации диапазона для последовательностей, не имеющих этой специальной формы, они используют декартовы деревья, чтобы преобразовать задачу минимизации диапазона в задачу наименьшего общего предка, а затем применяют технику обхода Эйлера, чтобы снова преобразовать проблему в проблему минимизации диапазона для последовательностей с этой специальной формой.

Та же самая проблема минимизации диапазона может также получить альтернативную интерпретацию в терминах двумерного поиска диапазона. Набор конечного числа точек в Декартова плоскость может использоваться для формирования декартового дерева путем сортировки точек по их Икс-координаты и используя y-координаты в этом порядке как последовательность значений, из которых формируется это дерево. Если S - подмножество входных точек в пределах некоторого вертикального перекрытия, определяемого неравенствами L ≤ Икс ≤ р, п крайняя левая точка в S (тот, у которого минимум Икс-координата), и q крайняя правая точка в S (тот, у которого максимум Икс-координата), затем наименьшего общего предка п и q в декартовом дереве - самая нижняя точка плиты. Трехсторонний запрос диапазона, в котором задача состоит в том, чтобы перечислить все точки в пределах области, ограниченной тремя неравенствами L ≤ Икс ≤ р и y ≤ Т, можно ответить, найдя эту самую нижнюю точку б, сравнивая его y-координировать с Т, и (если точка лежит в пределах трехсторонней области) рекурсивно продолжается в двух плитах, ограниченных между п и б и между б и q. Таким образом, после того, как крайняя левая и самая правая точки на плите определены, все точки в трехсторонней области могут быть перечислены с постоянным временем для каждой точки.[4]

Та же самая конструкция наименьших общих предков в декартовом дереве позволяет построить структуру данных с линейным пространством, которая допускает расстояния между парами точек в любом ультраметрическое пространство для запроса в постоянное время на запрос. Расстояние в пределах ультраметрики такое же, как минимаксный путь вес в минимальное остовное дерево метрики.[5] Из минимального остовного дерева можно построить декартово дерево, корневой узел которого представляет собой самое тяжелое ребро минимального остовного дерева. Удаление этого ребра разбивает минимальное остовное дерево на два поддерева, и декартовы деревья, рекурсивно построенные для этих двух поддеревьев, образуют потомков корневого узла декартова дерева. Листья декартового дерева представляют собой точки метрического пространства, а наименьший общий предок двух листьев в декартовом дереве - это самое тяжелое ребро между этими двумя точками в минимальном остовном дереве, вес которого равен расстоянию между двумя точками. . После того, как минимальное остовное дерево найдено и веса его ребер отсортированы, декартово дерево может быть построено за линейное время.[6]

Treaps

Поскольку декартово дерево является двоичным деревом, его естественно использовать как двоичное дерево поиска для упорядоченной последовательности значений. Однако определение декартового дерева на основе тех же значений, которые образуют ключи поиска бинарного дерева поиска, не работает должным образом: декартово дерево отсортированной последовательности - это просто дорожка, с корнем в его крайней левой конечной точке, и двоичный поиск в этом дереве вырождается в последовательный поиск в пути. Однако можно создавать более сбалансированные деревья поиска, генерируя приоритет значения для каждого ключа поиска, которые отличаются от самого ключа, сортировка входных данных по их значениям ключей и использование соответствующей последовательности приоритетов для создания декартова дерева. Эту конструкцию можно эквивалентно рассматривать в геометрической структуре, описанной выше, в которой Икс-координатами набора точек являются ключи поиска и y-координаты - это приоритеты.

Эту идею применил Зайдель и Арагон (1996), который предложил использовать случайные числа в качестве приоритета. Структура данных, полученная в результате этого случайного выбора, называется трогать, благодаря сочетанию двоичного дерева поиска и функций двоичной кучи. Вставка в treap может быть выполнена, вставив новый ключ как лист существующего дерева, выбрав для него приоритет, а затем выполнив вращение деревьев операции по пути от узла к корню дерева для исправления любых нарушений свойства кучи, вызванных этой вставкой; аналогичным образом удаление может быть выполнено путем постоянного изменения дерева, за которым следует последовательность поворотов по единственному пути в дереве.

Если приоритеты каждого ключа выбираются случайным образом и независимо один раз, когда ключ вставляется в дерево, результирующее декартово дерево будет иметь те же свойства, что и случайное двоичное дерево поиска, дерево, вычисленное путем вставки ключей в случайно выбранный перестановка начиная с пустого дерева, при каждой вставке предыдущая древовидная структура остается неизменной, а новый узел вставляется как лист дерева. Случайные бинарные деревья поиска изучались гораздо дольше и, как известно, ведут себя хорошо как деревья поиска (у них есть логарифмический глубина с большой вероятностью); такое же хорошее поведение переносится и на трепы. Также возможно, как было предложено Арагоном и Зайделем, изменить приоритеты часто используемых узлов, заставляя их двигаться к корню treap и ускоряя будущие обращения для тех же ключей.

Эффективная конструкция

Декартово дерево может быть построено в линейное время Один из методов - просто обработать значения последовательности в порядке слева направо, сохраняя декартово дерево узлов, обработанных до сих пор, в структуре, которая позволяет обход дерева как вверх, так и вниз. Для обработки каждого нового значения Икс, начните с узла, представляющего значение до Икс в последовательности и следуйте по пути от этого узла к корню дерева, пока не найдете значение y меньше чем Икс. Узел Икс становится правильным ребенком y, и предыдущий правый дочерний элемент y становится новым левым ребенком Икс. Общее время для этой процедуры линейно, потому что время, потраченное на поиск родителя y каждого нового узла Икс возможно заряжен против количества узлов, удаленных из крайнего правого пути в дереве.[4]

Альтернативный алгоритм построения линейного времени основан на все ближайшие меньшие значения проблема. Во входной последовательности можно определить левый сосед ценности Икс быть значением, которое встречается до Икс, меньше чем Икс, и находится ближе к Икс чем любое другое меньшее значение. В правый сосед определяется симметрично. Последовательность левых соседей может быть найдена с помощью алгоритма, поддерживающего куча содержащая подпоследовательность ввода. Для каждого нового значения последовательности Икс, стек выталкивается до тех пор, пока он не станет пустым или его верхний элемент не станет меньше Икс, а потом Икс помещается в стек. Левый сосед Икс это верхний элемент в то время Икс толкается. Правых соседей можно найти, применив тот же алгоритм стека к обратной последовательности. Родитель Икс в декартовом дереве является либо левым соседом Икс или правый сосед Икс, в зависимости от того, что существует и имеет большее значение. Левые и правые соседи также могут быть эффективно построены с помощью параллельные алгоритмы, поэтому эту формулировку можно использовать для разработки эффективных параллельных алгоритмов построения декартовых деревьев.[7]

Другой алгоритм линейного времени для построения декартовых деревьев основан на принципах «разделяй и властвуй». В частности, алгоритм рекурсивно строит дерево на каждой половине входных данных, а затем объединяет два дерева, беря правый стержень левого дерева и левый стержень правого дерева (оба являются путями, корень к листу порядок сортирует их значения от наименьшего к наибольшему) и выполняет стандартный слияние операция, заменяя эти два пути в двух деревьях одним путем, содержащим те же узлы. В объединенном пути преемник в отсортированном порядке каждого узла из левого дерева помещается в его правый дочерний элемент, а преемник каждого узла из правого дерева помещается в его левый дочерний элемент, ту же позицию, которая ранее использовалась для его преемник в позвоночнике. Левые потомки узлов левого дерева и правые потомки узлов правого дерева остаются без изменений. Алгоритм также можно распараллеливать, поскольку на каждом уровне рекурсии каждая из двух подзадач может быть вычислена параллельно, а операция слияния может быть эффективно распараллелить также.[8]

Применение в сортировке

Пары последовательных значений последовательности (показаны толстыми красными краями), ограничивающие значение последовательности Икс (более темная синяя точка). Стоимость включения Икс в отсортированном порядке, произведенном алгоритмом Левкопулоса – Петерсона, пропорциональна логарифм из этого количества пар скобок.

Левкопулос и Петерссон (1989) описать алгоритм сортировки на основе декартовых деревьев. Они описывают алгоритм как основанный на дереве с максимумом в корне, но его можно напрямую модифицировать для поддержки декартова дерева с условием, что минимальное значение находится в корне. Для согласованности ниже описана именно эта модифицированная версия алгоритма.

Алгоритм Левкопулоса – Петерсона можно рассматривать как версию сортировка выбора или куча сортировки который поддерживает приоритетная очередь возможных минимумов, и который на каждом шаге находит и удаляет минимальное значение в этой очереди, перемещая это значение в конец выходной последовательности. В их алгоритме очередь с приоритетом состоит только из элементов, родительский элемент которых в декартовом дереве уже найден и удален. Таким образом, алгоритм состоит из следующих шагов:

  1. Построить декартово дерево для входной последовательности
  2. Инициализировать приоритетную очередь, изначально содержащую только корень дерева
  3. Пока приоритетная очередь не пуста:
    • Найдите и удалите минимальное значение Икс в очереди приоритетов
    • Добавлять Икс к выходной последовательности
    • Добавьте декартово дерево потомков Икс в приоритетную очередь

Как показывают Левкопулос и Петерссон, для входных последовательностей, которые уже почти отсортированы, размер очереди приоритетов останется небольшим, что позволяет этому методу воспользоваться преимуществами почти отсортированного ввода и работать быстрее. В частности, время работы этого алгоритма в наихудшем случае составляет O (п журналk), куда k среднее по всем значениям Икс в последовательности из числа последовательных пар значений последовательности, Икс. Они также доказывают нижнюю оценку, утверждающую, что для любого п и k = ω (1), любой алгоритм сортировки на основе сравнения должен использовать Ω (п журналk) сравнения для некоторых входов.

История

Декартовы деревья были введены и названы Вюйлемен (1980). Название происходит от Декартова координата система для плоскости: в версии этой структуры Вюйлемена, как и в описанном выше приложении двумерного поиска по диапазону, декартово дерево для набора точек имеет отсортированный порядок точек по их Икс-координаты как его симметричный порядок обхода, и он имеет свойство кучи в соответствии с y-координаты точек.Габоу, Бентли и Тарджан (1984) и последующие авторы следовали приведенному здесь определению, в котором декартово дерево определяется из последовательности; это изменение обобщает геометрическую настройку Vuillemin, чтобы разрешить последовательности, отличные от сортированного порядка Икс-координаты, а также позволяет применять декартово дерево к негеометрическим задачам.

Заметки

  1. ^ В некоторых ссылках порядок обратный, поэтому родительский узел любого узла всегда имеет большее значение, а корневой узел - максимальное значение.
  2. ^ Габоу, Бентли и Тарджан (1984); Бендер и Фарач-Колтон (2000).
  3. ^ Харел и Тарджан (1984); Шибер и Вишкин (1988).
  4. ^ а б Габоу, Бентли и Тарджан (1984).
  5. ^ Ху (1961); Леклерк (1981)
  6. ^ Демейн, Ландау и Вейманн (2009).
  7. ^ Беркман, Шибер и Вишкин (1993).
  8. ^ Shun & Blelloch (2014).

Рекомендации

  • Бендер, Майкл А .; Фарач-Колтон, Мартин (2000), «Возвращение к проблеме LCA», Материалы 4-го латиноамериканского симпозиума по теоретической информатике, Springer-Verlag, Конспект лекций по информатике 1776, с. 88–94..
  • Беркман, Омер; Шибер, Барух; Вишкин, Узи (1993), «Оптимальные дважды логарифмические параллельные алгоритмы, основанные на нахождении всех ближайших меньших значений», Журнал алгоритмов, 14 (3): 344–370, Дои:10.1006 / jagm.1993.1018.
  • Демейн, Эрик Д.; Landau, Gad M .; Вейманн, Орен (2009), «О декартовых деревьях и минимальных запросах диапазона», Автоматы, языки и программирование, 36-й международный коллоквиум, ICALP 2009, Родос, Греция, 5-12 июля 2009 г., Конспект лекций по информатике, 5555, стр. 341–353, Дои:10.1007/978-3-642-02927-1_29, HDL:1721.1/61963, ISBN 978-3-642-02926-4.
  • Фишер, Йоханнес; Хойн, Волкер (2006), «Теоретические и практические усовершенствования проблемы RMQ с приложениями к LCA и LCE», Материалы 17-го ежегодного симпозиума по комбинаторному сопоставлению с образцом, Конспект лекций по информатике, 4009, Springer-Verlag, стр. 36–48, Дои:10.1007/11780441_5, ISBN 978-3-540-35455-0
  • Фишер, Йоханнес; Хойн, Волкер (2007), «Новое краткое представление RMQ-информации и улучшения в расширенном массиве суффиксов», Материалы Международного симпозиума по комбинаторике, алгоритмам, вероятностным и экспериментальным методологиям, Конспект лекций по информатике, 4614, Springer-Verlag, стр. 459–470, Дои:10.1007/978-3-540-74450-4_41, ISBN 978-3-540-74449-8
  • Габоу, Гарольд Н .; Бентли, Джон Луи; Тарджан, Роберт Э. (1984), "Масштабирование и связанные с ним методы для геометрических задач", STOC '84: Proc. 16-й симпозиум ACM. Теория вычислений, Нью-Йорк, Нью-Йорк, США: ACM, стр. 135–143, Дои:10.1145/800057.808675, ISBN 0-89791-133-4.
  • Харел, Дов; Тарджан, Роберт Э. (1984), «Быстрые алгоритмы поиска ближайших общих предков», SIAM Журнал по вычислениям, 13 (2): 338–355, Дои:10.1137/0213024.
  • Ху, Т. С. (1961), "Проблема маршрута с максимальной пропускной способностью", Исследование операций, 9 (6): 898–900, Дои:10.1287 / opre.9.6.898, JSTOR 167055.
  • Леклерк, Бруно (1981), "Описание Combinatoire des ultramétriques", Centre de Mathématique Sociale. École Pratique des Hautes Études. Mathématiques et Sciences Humaines (на французском языке) (73): 5–37, 127, МИСТЕР 0623034.
  • Левкопулос, Христос; Петерссон, Ола (1989), «Heapsort - адаптировано для предварительно отсортированных файлов», WADS '89: Материалы семинара по алгоритмам и структурам данных, Конспект лекций по информатике, 382, Лондон, Великобритания: Springer-Verlag, стр. 499–509, Дои:10.1007/3-540-51542-9_41.
  • Зайдель, Раймунд; Арагон, Сесилия Р. (1996), «Рандомизированные деревья поиска», Алгоритмика, 16 (4/5): 464–497, Дои:10.1007 / s004539900061.
  • Шибер, Барух; Вишкин, Узи (1988), «Об обнаружении низших общих предков: упрощение и распараллеливание», SIAM Журнал по вычислениям, 17 (6): 1253–1262, Дои:10.1137/0217079.
  • Шун, Джулиан; Блеллох, Гай Э. (2014), «Простой алгоритм параллельного декартова дерева и его применение для построения параллельного суффиксного дерева», ACM-транзакции на параллельных вычислениях, 1: 1–20, Дои:10.1145/2661653.
  • Vuillemin, Жан (1980), «Универсальный взгляд на структуры данных», Коммуникации ACM, Нью-Йорк, Нью-Йорк, США: ACM, 23 (4): 229–239, Дои:10.1145/358841.358852.