ARBOLES AVL

ARBOLES AVL


Inserción

La inserción de un elemento en un árbol AVL es idéntica que en un árbol binario de búsqueda la diferencia se encuentra en la comprobación que hay que realizar posteriormente en los árboles AVL.
En un árbol AVL tras realizar la inserción hay que comprobar que se sigue manteniendo la condición de equilibrio, o lo que es lo mismo, que la altura del subárbol izquierdo y la del subárbol derecho difieran en una unidad o sean iguales. Si se produce un desequilibrio hay que re equilibrar la estructura para que siga siendo un árbol AVL.
Vamos a ver los mecanismos de re equilibrado de los árboles AVL:

Rotación simple.
Rotación simple en árboles AVL

El nodo insertado es el marcado con una X. Esta inserción provoca un desequilibro en el nodo B, que se soluciona con esta rotación.

Rotación doble.
Rotación doble en árboles AVL
El nodo insertado puede ser una de las dos X, provocando el desequilibrio en el nodo C.
Vamos a ver dos ejemplos reales:

Rotación simple.
Ejemplo de rotación simple en árboles AVL
Rotación doble.
Ejemplo de rotación doble en árboles AVL

Borrar

El procedimiento de borrado es el mismo que en el caso de arboles binarios de búsqueda  La diferencia se encuentra en el proceso de re equilibrado posterior. Este proceso es idéntico al que se realiza en la inserción, la única diferencia es que en la inserción tras realizar una rotación el árbol ya estaba equilibrado, mientras que en el borrado puede ser necesario realizar mas de una rotación.

Ejemplo:
Si eliminamos del siguiente árbol el nodo 3, el árbol se desequilibra en el nodo 2.
Una rama del árbol tiene dos niveles más de altura que otra rama
Tras aplicar una rotación simple, el árbol resultante es:
Árbol reorganizado, ahora todas sus ramas tienen la misma altura
Otras operaciones
Las operaciones adicionales en un árbol AVl son análogas a las de arboles binarios de busqueda

No hay comentarios.: