Академический Документы
Профессиональный Документы
Культура Документы
Los Árboles son las estructuras de datos mas utilizadas, pero también una de las mas
complejas, Los Árboles se caracterizan por almacenar sus nodos en forma jerárquica y no en
forma lineal como las Listas Ligadas, Colas,Pilas,etc., de las cuales ya hemos hablado en días
pasados.
Los arboles a demas de los nodos tiene otras propiedades importantes que son utilizadas en
diferente ámbitos los cuales son:
Nivel: Nos referimos como nivel a cada generación dentro del árbol. Por ejemplo, cuando a un
nodo hoja le agregamos un hijo, el nodo hoja pasa a ser un nodo rama pero a demas el árbol
crece una generación por lo que el Árbol tiene un nivel mas.Cada generación tiene un número
de Nivel distinto que las demas generaciones.
El peso se puede calcular mediante cualquier tipo de recorrido el cual valla contando los
nodo a medida que avanza sobre la estructura. El peso es un árbol es igual a la suma
del peso de los sub-árboles hijos + 1
peso = peso(hijo1) + peso(hijo2) + peso(hijoN)+ 1
Nota: Los tipos de recorridos los veremos mas adelante.
Orden: El Orden de un árbol es el número máximo de hijos que puede tener un Nodo.
El peso se puede calcular mediante cualquier tipo de recorrido el cual valla contando los
nodo a medida que avanza sobre la estructura. El peso es un árbol es igual a la suma
del peso de los sub-árboles hijos + 1
peso = peso(hijo1) + peso(hijo2) + peso(hijoN)+ 1
Nota: Los tipos de recorridos los veremos mas adelante.
Orden: El Orden de un árbol es el número máximo de hijos que puede tener un Nodo.
Notemos que un Árbol con Orden = 1 no tendría sentido ya que seria una estructura lineal. ya
que cada nodo solo podría tener un Hijo y tendríamos un Árbol como la Imagen de la Fig.1.
Este valor no lo calculamos, si no que ya lo debemos conocer cuando diseñamos nuestra
estructura, ya que si queremos calcular esto lo que obtendremos es el grado(hablamos de el
continuación).
Grado: El grado se refiere al número mayor de hijos que tiene alguno de los nodos del Árbol y
esta limitado por el Orden, ya que este indica el número máximo de hijos que puede tener un
nodo.
El grado se calcula contando de forma recursiva el número de hijos de cada sub-árbol hijo y el
numero de hijos del nodo actual para tomar el mayor, esta operación se hace de forma recursiva
para recorrer todo el árbol.
grado = max(contarHijos(hijo1),contarHijos(hijo2), contarHijos(hijoN), contarHijos(this))
Sub-Árbol: Conocemos como Sub-Árbol a todo Árbol generado a partir de una sección
determinada del Árbol, Por lo que podemos decir que un Árbol es un nodo Raíz con N Sub-
Árboles.
Fig. 8: En la imagen de puede apreciar que un Árbol esta compuesto por una seria de Sub-Arboles
los cual conforman toda la estructura.
Existen escenarios donde podemos sacar un Sub-Árboles del Árbol para procesarlo de forma
separada, de esta forma el Sub-Árboles pasa a ser un Árbol independiente, También podemos
eliminar Sub-Árboles completos, Agregarlos,entre otras operaciones.
Árbol n-ario
los arboles n-arios son aquellos arboles donde el número máximo de hijos por nodo es de N,
en la figura 7 podemos apreciar dos árboles con grado 2 y grado 3, estos dos arboles también
los podemos definir como Árbol n-ario con n = 2 y n=3 respectivamente.
Árboles binarios
Esta estructura se caracteriza por que cada nodo solo puede tener máximo 2 hijo,
Árbol binario lleno: Es aquel que el que todos los nodos tiene cero o 2 hijos con excepción de
la Raíz.
Búsquedas no informadas
Las búsquedas no informadas son aquellas en que se realiza el viaje por todo el árbol sin tener
una pista de donde pueda estar el dato deseado. Este tipo de búsquedas también se conocen
como búsquedas a ciegas.
Para comprender mejor que es una búsqueda no informada expondremos el siguiente ejemplo:
Imagine que vamos por la carretera y de repente encontramos dos caminos, el problema a qui
es que uno después de 50 kilómetros esta en construcción y el otro nos lleva a nuestro destino,
sin embargo ninguno de los caminos tiene señalamiento. Lo que tendríamos que hacer es
recorrer el primero camino y después de 50 kilómetros encontrarnos con que el camino esta en
construcción, entonces tendríamos que regresar para irnos por el segundo camino,el cual nos
lleva a nuestro destino(Para esto ya recorrimos los 50 kilómetros de ida y los 50 kilómetros de
regreso lo que nos da 100 kilómetros mas a nuestra ruta).
A este tipo de escenarios en los cuales las búsquedas de hacen a ciegas los conocemos como
búsquedas no informadas.
Las siguientes métodos de búsqueda que veremos a continuación(Búsqueda en profundad y
Búsqueda en amplitud) pertenecen a las búsquedas no informadas.
Búsqueda en profundidad
Recorrido Pre-orden: El recorrido inicia en la Raíz y luego se recorre en pre-orden cada
unos de los sub-árboles de izquierda a derecha.
Esta definición puede ser un poco compleja de entender por lo que mejor les dejo la siguiente
imagen.
Fig. 12:En la imagen podemos ver el orden en que es recorrido el árbol iniciando desde la Raíz.
Fig. 13: Codigo de una función recursiva que recorre un árbol en preorden.
Recorrido Pos-orden: Se recorre el pos-orden cada uno de los sub-árboles y al final se recorre
la raíz.
Para comprender mejor esta definición observemos la siguiente imagen:
Fig. 14: En la imagen podemos observar como se realiza el recorrido en Pos-Orden, Sin embargo es
importante notar que el primer nodo que se imprime no es la Raiz pues en este recorrido la Raíz
de cada Sub-Árbol es procesado al final, ya que toda su descendencia ha sido procesada.
Fig. 17: Código de una función recursiva que recorre un árbol en inorden
Búsqueda en amplitud.
Se recorre primero la raíz, luego se recorren los demas nodos ordenados por el nivel al que
pertenecen en orden de Izquierda a derecha.
Este tipo de búsqueda se caracteriza por que la búsqueda se hace nivel por nivel y de izquierda
a derecha.
Fig. 18: En la imagen se observa como es que un nodo es buscado mediante la búsqueda en
profundidad.
En la imagen podemos observa que el árbol es recorrido en su totalidad pero esto no siempre
es a sí, ya que el algoritmo se detiene cuando el elemento buscado es encontrado.