Изменения

Перейти к: навигация, поиск

АВЛ-дерево

3 байта убрано, 22:50, 1 апреля 2012
Слияние двух AVL-деревьев
Остальные операции не меняют структуры дерева, поэтому выполняются так же, как и в [[Дерево поиска, наивная реализация|наивной реализации]] дерева поиска.
===Слияние двух AVL-деревьев===
[[File:Tavltree1.jpg|thumb|alt=Example alt text| Дерево <tex>T_1</tex> и <tex>T_2</tex> до слияния]]
[[File:Tavltree2.jpg|thumb|alt=Example alt text| Дерево <tex>T_2</tex> после слияния]]
Дано два дерева <tex>T_1</tex> и <tex>T_2</tex>, все ключи в <tex>T_1</tex> меньше ключей в <tex>T_2</tex>, <tex>h(T_1) \le h(T_2)</tex>.
 
 
[[File:Tavltree1.jpg|thumb|alt=Example alt text| Дерево <tex>T_1</tex> и <tex>T_2</tex> до слияния]]
В дереве <tex>T_1</tex> удаляем самую правую вершину, назовём её <tex>b</tex>. Высота дерева <tex>T_1</tex> может уменьшиться на единицу. В дереве <tex>T_2</tex> идём от корня всегда в левое поддерево и, когда высота этого поддерева <tex>P</tex> будет равна высоте дерева <tex>T_1</tex>, делаем новое дерево <tex>S</tex>, корнем <tex>S</tex> будет вершина <tex>b</tex>, левым поддеревом будет дерево <tex>T_1</tex>, а правым дерево <tex>P</tex>. Теперь в дереве <tex>T_2</tex> у вершины, в которой мы остановились при спуске, левым поддеревом делаем дерево <tex>S</tex> и запускаем балансировку. Таким образом, дерево <tex>T_2</tex> будет результатом слияния двух АВЛ-деревьев.
 
[[File:Tavltree2.jpg|thumb|alt=Example alt text| Дерево <tex>T_2</tex> после слияния]]
== Литература ==
59
правок

Навигация