jueves, 10 de noviembre de 2011

ARBOLES

Un árbol se define como una colección de nodos organizados en forma recursiva. Cuando hay 0 nodos se dice que el árbol esta vacío, en caso contrario el árbol consiste en un nodo denominado raíz, el cual tiene 0 o más referencias a otros árboles, conocidos como subárboles. Las raíces de los subárboles se denominan hijos de la raíz, y consecuentemente la raíz se denomina padre de las raíces de sus subárboles.
Los nodos que no poseen hijos se denominan hojas. Dos nodos que tienen el padre en común se denominan hermanos Un camino entre un nodo n1 y un nodo nk está definido como la secuencia de nodos n1, n2, ..., nk tal que ni es padre de ni+1, 1 <= i < k. El largo del camino es el número de referencias que componen el camino, que para el ejemplo son k-1. Existe un camino desde cada nodo del árbol a sí mismo y es de largo 0. Nótese que en un árbol existe un único camino desde la raíz hasta cualquier otro nodo del árbol. A partir del concepto de camino se definen los conceptos de ancestro y descendiente: un nodo n es ancestro de un nodo m si existe un camino desde n a m; un nodo n es descendiente de un nodo m si existe un camino desde m a n.
Se define la profundidad del nodo nk como el largo del camino entre la raíz del arbol y el nodo nk. Esto implica que la profundidad de la raíz es siempre 0. La altura de un nodo nk es el máximo largo de camino desde nk hasta alguna hoja. Esto implica que la altura de toda hoja es 0. La altura de un árbol es igual a la altura de la raíz, y tiene el mismo valor que la profundidad de la hoja más profunda. La altura de un árbol vacío se define como -1.
La siguiente figura muestra un ejemplo de los conceptos previamente descritos:



  • A es la raíz del árbol.
  • A es padre de B, C y D.
  • E y F son hermanos, puesto que ambos son hijos de B.
  • E, J, K, L, C, P, Q, H, N y O son las hojas del árbol.
  • El camino desde A a J es único, lo conforman los nodos A-B-F-J y es de largo 3.
  • D es ancestro de P, y por lo tanto P es descendiente de D.
  • L no es descendiente de C, puesto que no existe un camino desde C a L.
  • La profundidad de C es 1, de F es 2 y de Q es 4.
  • La altura de C es 0, de F es 1 y de D es 3.
  • La altura del árbol es 4 (largo del camino entre la raíz A y la hoja más profunda, P o Q). 



TIPOS DE ARBOL

  • Árboles binarios

Un árbol binario es un árbol en donde cada nodo posee 2 referencias a subárboles (ni más, ni menos). En general, dichas referencias se denominan izquierda y derecha, y consecuentemente se define el subárbol izquierdo y subárbol derecho del arbol.


 
Los nodos en sí que conforman un árbol binario se denominan nodos internos, y todas las referencias que son null se denominan nodos externos.




RECORRIDO.-

Existen tres formas principales para recorrer un árbol binario en forma recursiva. Estas son:
  • Preorden: raíz - subárbol izquierdo - subárbol derecho.
  • Inorden: subárbol izquierdo - raiz - subárbol derecho.
  • Postorden: subárbol izquierdo - subárbol derecho - raíz.
Por ejemplo, al recorrer el árbol de expresiones anterior en preorden se obtiene:


* + a b - c d
Al recorrer el árbol en inorden se obtiene:


a + b * c - d
Al recorrer el árbol en postorden se obtiene:


a b + c d - *
La expresión que se obtiene con el recorrido en postorden se conoce como notación polaca.


Árboles generales

En un árbol general cada nodo puede poseer un número indeterminado de hijos. La implementación de los nodos en este caso se realiza de la siguiente manera: como no se sabe de antemano cuantos hijos tiene un nodo en particular se utilizan dos referencias, una a su primer hijo y otra a su hermano más cercano. La raíz del árbol necesariamente tiene la referencia a su hermano como null.




Nótese que todo árbol general puede representarse como un árbol binario, con la salvedad que el hijo derecho de la raíz es siempre null. Si se permite que la raíz del árbol tenga hermanos, lo que se conoce como bosque, entonces se tiene que el conjunto de los bosques generales es isomorfo al conjunto de los árboles binarios. En efecto, las propiedades vistas en los árboles binarios se siguen cumpliendo en los árboles generales. 

      








                                                                                                                                                            
                
















1 comentario:

  1. Hola, llegue aqui sin saber como! quiero su pack de arboles!

    ResponderEliminar