WAVL дерево - WAVL tree
В Информатика, а WAVL дерево или же слабое дерево AVL это самобалансирующееся двоичное дерево поиска. Деревья WAVL названы в честь Деревья АВЛ, еще один тип сбалансированного дерева поиска, который тесно связан как с деревьями AVL, так и с красно-черные деревья, которые все попадают в общие рамки ранжируйте сбалансированные деревья.Как и другие сбалансированные деревья двоичного поиска, деревья WAVL могут обрабатывать операции вставки, удаления и поиска во времени. О(бревно п) за операцию.[1][2]
Деревья WAVL объединяют в себе некоторые из лучших свойств как деревьев AVL, так и красно-черных деревьев. Одно из преимуществ AVL-деревьев перед красно-черными деревьями заключается в том, что они более сбалансированы: они имеют максимальную высоту. (для дерева с п элементы данных, где это Золотое сечение ), а у красно-черных деревьев максимальная высота больше, . Если дерево WAVL создается с использованием только вставок без удалений, то оно имеет ту же небольшую границу высоты, что и дерево AVL. С другой стороны, красно-черные деревья имеют преимущество перед деревьями AVL в меньшей реструктуризации их деревьев. В деревьях AVL каждое удаление может потребовать логарифмического числа вращение деревьев операции, в то время как у красно-черных деревьев есть более простые операции удаления, которые используют только постоянное количество поворотов дерева. Деревья WAVL, как и красно-черные деревья, используют только постоянное количество оборотов дерева, и это постоянное даже лучше, чем для красно-черных деревьев.[1][2]
Деревья WAVL были введены Хэуплер, Сен и Тарьян (2015). Те же авторы также представили общий взгляд на деревья AVL, деревья WAVL и красно-черные деревья как на тип дерева со сбалансированным рангом.[2]
Определение
Как и в случае с деревьями двоичного поиска в более общем смысле, дерево WAVL состоит из набора узлы, двух типов: внутренние узлы и внешние узлы. Внутренний узел хранит элемент данных и связан со своим родителем (за исключением назначенного корневого узла, у которого нет родителя) и ровно с двумя дочерними элементами в дереве, левым и правым дочерними элементами. Внешний узел не несет данных и имеет ссылку только на своего родителя в дереве. Эти узлы организованы в виде двоичного дерева, так что для любого внутреннего узла Икс родители левых и правых детей Икс находятся Икс сам. Внешние узлы образуют листья дерева.[3] Элементы данных расположены в дереве таким образом, что обход по порядку дерева перечисляет элементы данных в отсортированном порядке.[4]
Что отличает WAVL-деревья от других типов двоичного дерева поиска, так это использование разряды. Это числа, связанные с каждым узлом, которые обеспечивают приближение расстояния от узла до его самого дальнего листового потомка. В отличие от деревьев AVL, где ранги определяются как такие же, как высота узлов, ранги не всегда равны высотам. в деревьях WAVL. В разница в рангах узла x определяется как разница между рангом родителя x и рангом x. Звания должны соответствовать следующим свойствам:[1][2]
- Свойство внешнего узла: каждый внешний узел имеет ранг 0[5]
- Свойство Rank-Difference: если некорневой узел имеет ранг р, то ранг его родителя должен быть либо р + 1 или же р + 2. Другими словами, разность рангов для любого некорневого узла равна 1 или 2.[1]
- Свойство внутреннего узла: внутренний узел с двумя внешними дочерними элементами должен иметь ранг ровно 1.
Операции
Поиск
В поисках ключа k в дереве WAVL во многом такая же, как в любой структуре данных сбалансированного двоичного дерева поиска. Один начинается с корня дерева, а затем многократно сравнивает k с элементом данных, хранящимся в каждом узле на пути от корня, следуя пути к левому дочернему элементу узла, когда k меньше значения в узле или вместо этого следует по пути к правому дочернему элементу, когда k больше, чем значение в узле. Когда узел со значением, равным k или внешний узел, поиск останавливается.[6]
Если поиск останавливается на внутреннем узле, ключ k был найден. Если вместо этого поиск останавливается на внешнем узле, то позиция, в которой k был бы вставлен (если бы был вставлен) был найден.[6]
Вставка
Вставка внутреннего узла с ключом k в дерево WAVL требует поиска k в дереве, заканчивающемся внешним узлом, затем замена этого внешнего узла новым внутренним узлом с двумя внешними дочерними элементами и, наконец, перебалансировка дерева. Шаг перебалансировки может выполняться как сверху вниз, так и снизу вверх,[2] но восходящая версия ребалансировки наиболее точно соответствует деревьям AVL.[1][2]
Перебалансировка снизу вверх начинается с рассмотрения разницы рангов между узлом - первоначально вновь вставленным узлом - и его родителем. Если родителя нет, баланс восстанавливается. До начала вставки разница рангов между родительским узлом и узлом составляла 1 или 2, но эта разница была уменьшена на 1, поскольку субтитры, загруженные в узел, стали выше. Если новая разница рангов между родительским узлом и узлом равна 1, баланс восстанавливается. В противном случае, если брат или сестра, другой дочерний элемент родителя, имеет разность рангов 1 с родителем, продвигайте родителя - повышайте его ранг, увеличивая ранговые различия между ним и каждым из его потомков - и продолжайте балансировать со старым родителем как новым. узел.
Наконец, при разнице рангов 0 и 2 для узла и сестры одно или два поворота дерева с соответствующими корректировками разницы рангов могут восстановить баланс. Промежуточный дочерний элемент node - это тот, у которого ключ между ключами node и parent. Если разность рангов для этого ребенка и узла равна 2, поверните, чтобы переместить узел вверх в дереве и вниз, затем понизьте ранг родителя - уменьшите его ранг, скорректировав разность рангов вокруг него - и баланс будет восстановлен. В противном случае поверните, чтобы переместить дочерний элемент вверх, а узел вниз, затем поверните снова, чтобы переместить дочерний элемент вверх, а родительский элемент - вниз. Повысьте уровень ребенка, понизьте уровень узла и родителя, и баланс будет восстановлен.
Таким образом, в целом процедура вставки состоит из поиска, создания постоянного числа новых узлов, логарифмического числа изменений ранга и постоянного числа вращений дерева.[1][2]
Удаление
Удаление внутреннего узла из WAVL-дерева начинается с обычногоудаление двоичного дерева поиска. Для внутреннего узла без внешнего дочернего элемента это означает поиск его преемника в дереве, обмен узла с его преемником, а затем удаление узла из его новой позиции в дереве, где его левый дочерний элемент обязательно является внешним узлом. Чтобы удалить внутренний узел с внешним дочерним узлом, замените узел другим дочерним.
Перебалансировка снизу вверх начинается с рассмотрения разницы рангов между узлом - первоначально узлом, который заменил удаленный узел - и его родителем. Если родителя нет, баланс восстанавливается. До начала удаления разница рангов между родительским узлом и узлом составляла 1 или 2, но эта разница была увеличена на 1, потому что субтитры, загружаемые в узле, сократились. Если у родителя теперь есть два внешних дочерних элемента, свойство internal-node нарушается, потому что у родительского элемента есть ранг 2. Родитель должен быть понижен в ранге, и перебалансировка продолжается с родительским узлом в качестве узла, который является корнем слишком короткого поддерева.
Если у узла нет родителя, баланс восстанавливается. Если разность рангов между узлом и родителем выросла с 1 до 2, баланс восстанавливается. В противном случае, если родственный брат, другой дочерний элемент родителя, имеет разность рангов 2 с родителем, понизьте ранг родителя - уменьшите его ранг, уменьшив разность рангов между ним и каждым из его потомков - и продолжите перебалансировку со старым родителем. как новый узел. В противном случае, если два дочерних элемента одноуровневого узла имеют разность рангов 2 с одноуровневым узлом, понизьте уровень родительского и дочернего узлов и продолжите балансировку со старым родительским узлом в качестве нового узла.
Наконец, при разнице рангов 3 и 1 для узла и брата и сестре, а также когда у родного брата есть дочерний элемент с разницей рангов 1, одна или две трехэтапные операции с соответствующими корректировками разницы рангов могут восстановить баланс. Определите детей брата или сестры как племянницу и племянника, где ключ племянницы находится между ключами родителя и брата, а ключ племянника - нет. Если разность рангов между братьями и сестрами и племянником равна 1, поверните, чтобы сдвинуть одного из них вверх, а родителя вниз, повысить одного и того же и понизить уровень родителя, по крайней мере, дважды, если необходимо, чтобы избежать нарушения свойства внутреннего узла. В противном случае, если разность рангов между братьями и сестрами и племянником равна 1, поверните, чтобы переместить племянницу вверх, а брата или сестру вниз, поверните снова, чтобы переместить племянницу вверх, а родителя вниз, дважды повысить племянницу, один раз понизьте в должности родителя и дважды понизьте в должности родителя.
В целом, удаление состоит из поиска вниз, чтобы найти узел с внешним потомком, удаления постоянного числа новых узлов, логарифмического числа изменений ранга и постоянного числа поворотов дерева. [1] [2]
Целесообразно сравнить результат удаления, которое вызовет ротацию на нескольких уровнях в дереве AVL, с ротацией и изменениями ранга, выполненными в дереве WAVL. На втором изображении узел со значением 12 был удален с последующим поворотом вправо и присвоением всем внешним узлам нулевого ранга.
Вычислительная сложность
Каждый поиск, вставка или удаление в дереве WAVL включает следование единственному пути в дереве и выполнение постоянного количества шагов для каждого узла на пути. В дереве WAVL с п элементы, которые были только вставлены, максимальная длина пути составляет . Если могли произойти и вставки, и удаления, максимальная длина пути составляет . Следовательно, в любом случае время наихудшего случая для каждого поиска, вставки или удаления в дереве WAVL с п элементы данных О(бревно п).
Кроме того, после нахождения узла для вставки и удаления амортизированная сложность операций реструктуризации дерева остается постоянной. Добавление или удаление самого узла - это постоянное время, количество поворотов всегда самое постоянное, и можно показать, что общее количество изменений ранга в узлах линейно зависит от количества как вставок, так и удалений.
Связанные структуры
Деревья WAVL тесно связаны с обоими Деревья АВЛ и красно-черные деревья.Каждому дереву AVL можно присвоить ранги его узлам таким образом, чтобы оно стало деревом WAVL. И каждое WAVL-дерево может иметь свои узлы, окрашенные в красный и черный цвета (и переназначение их рангов) таким образом, чтобы оно превращалось в красно-черное дерево. Однако некоторые деревья WAVL не происходят из деревьев AVL таким образом, а некоторые красно-черные деревья не происходят из деревьев WAVL таким образом.
Деревья АВЛ
Дерево AVL - это своего рода сбалансированное двоичное дерево поиска, в котором два дочерних элемента каждого внутреннего узла должны иметь высоту, различающуюся не более чем на единицу.[7] Высота внешнего узла равна нулю, а высота любого внутреннего узла всегда равна единице плюс максимум высот двух его дочерних узлов. Таким образом, функция высоты дерева AVL подчиняется ограничениям дерева WAVL, и мы можем преобразовать любое дерево AVL в дерево WAVL, используя высоту каждого узла в качестве его ранга.[1][2]
Ключевое различие между деревом AVL и деревом WAVL возникает, когда у узла есть два потомка с одинаковым рангом или высотой. В дереве AVL, если узел Икс имеет двух детей одного роста час как друг друга, то высота Икс должно быть точно час + 1. Напротив, в дереве WAVL, если узел Икс имеет двоих детей одного ранга р как друг друга, то ранг Икс может быть р + 1 или же р + 2. Это связано с тем, что ранг не строго равен высоте в дереве WAVL. Эта большая гибкость рангов также приводит к большей гибкости структур: некоторые деревья WAVL не могут быть преобразованы в деревья AVL даже путем изменения их рангов, потому что они включают узлы, чья высота дочерних элементов отличается более чем на единицу.[2] Однако мы можем сказать, что все деревья AVL являются деревьями WAVL. Деревья AVL - это деревья WAVL без типа узла, у которого оба дочерних элемента имеют разность рангов 2.[1]
Если дерево WAVL создается только с использованием операций вставки, то его структура будет такой же, как структура дерева AVL, созданного той же последовательностью вставки, и его ранги будут такими же, как ранги соответствующего дерева AVL. Только посредством операций удаления дерево WAVL может отличаться от дерева AVL. В частности, это означает, что дерево WAVL, созданное только с помощью вставок, имеет высоту не более .[2]
Красно-черные деревья
А красно-черное дерево представляет собой сбалансированное двоичное дерево поиска, в котором каждый узел имеет цвет (красный или черный), удовлетворяющий следующим свойствам:
- Внешние узлы черные.
- Если внутренний узел красный, два его дочерних узла черные.
- Все пути от корня до внешнего узла имеют одинаковое количество черных узлов.
Красно-черные деревья могут быть эквивалентно определены в терминах системы рангов, хранящейся в узлах, удовлетворяющей следующим требованиям (отличным от требований к рангам в деревьях WAVL):
- Ранг внешнего узла всегда равен 0, а ранг его родителя всегда равен 1.
- Ранг любого некорневого узла равен либо рангу его родителя, либо рангу его родителя минус 1.
- Никакие два последовательных ребра на любом пути корень-лист не имеют разности рангов 0.
Эквивалентность между определениями на основе цвета и на основе ранга можно увидеть в одном направлении, раскрасив узел в черный цвет, если его родительский элемент имеет более высокий ранг, и в красный цвет, если его родитель имеет равный ранг. В другом направлении цвета можно преобразовать в ранги, сделав ранг черного узла равным количеству черных узлов на любом пути к внешнему узлу, и сделав ранг красного узла равным его родительскому узлу.[8]
Ранги узлов в дереве WAVL могут быть преобразованы в систему рангов узлов, подчиняющуюся требованиям для красно-черных деревьев, путем деления каждого ранга на два и округления до ближайшего целого числа.[9] Из-за этого преобразования для каждого WAVL-дерева существует допустимое красно-черное дерево с той же структурой. Потому что у красно-черных деревьев максимальная высота , то же самое верно и для WAVL-деревьев.[1][2] Однако существуют красно-черные деревья, которым нельзя дать допустимую функцию ранга WAVL-дерева.[2]
Несмотря на то, что с точки зрения древовидной структуры деревья WAVL являются частными случаями красно-черных деревьев, их операции обновления различны. Повороты дерева, используемые в операциях обновления дерева WAVL, могут вносить изменения, которые не разрешены в красно-черном дереве, потому что они фактически вызовут перекрашивание больших поддеревьев красно-черного дерева, а не изменение цвета только для одного путь в дереве.[2] Это позволяет деревьям WAVL в худшем случае выполнять меньшее количество вращений за одно удаление, чем красно-черным деревьям.[1][2]
Рекомендации
- ^ а б c d е ж грамм час я j Гудрич, Майкл Т.; Тамассия, Роберто (2015), «4.4 Слабые деревья AVL», Разработка алгоритмов и приложения, Wiley, стр. 130–138..
- ^ а б c d е ж грамм час я j k л м п Хёуплер, Бернхард; Сен, Сиддхартха; Тарджан, Роберт Э. (2015), "Деревья со сбалансированным рангом" (PDF), ACM-транзакции на алгоритмах, 11 (4): Ст. 30, 26, Дои:10.1145/2689412, МИСТЕР 3361215.
- ^ Гудрич и Тамассия (2015), Раздел 2.3, Деревья, стр. 68–83.
- ^ Гудрич и Тамассия (2015), Глава 3 Деревья двоичного поиска, стр. 89–114.
- ^ В этом мы следуем Гудрич и Тамассия (2015). В версии, описанной Хэуплер, Сен и Тарьян (2015), внешние узлы имеют ранг −1. Этот вариант очень мало влияет на операции с деревьями WAVL, но вызывает некоторые незначительные изменения в формуле преобразования деревьев WAVL в красно-черные деревья.
- ^ а б Гудрич и Тамассия (2015), Раздел 3.1.2 Поиск в дереве двоичного поиска, стр. 95–96.
- ^ Гудрич и Тамассия (2015), Раздел 4.2. Деревья AVL, стр. 120–125.
- ^ Гудрич и Тамассия (2015), Раздел 4.3 Красно-черные деревья, стр. 126–129.
- ^ В Хэуплер, Сен и Тарьян (2015) преобразование выполняется путем округления в меньшую сторону, поскольку ранги внешних узлов равны -1, а не 0. Гудрич и Тамассия (2015) дают формулу, которая также округляется в меньшую сторону, но поскольку они используют ранг 0 для внешних узлов, их формула неправильно присваивает красно-черный ранг 0 внутренним узлам с рангом 1 WAVL.