Nous allons travailler sur la structure de donnée "arbre". Cette structure n'est pas linéaire mais hiérarchique.
Arbre
Un arbre est une structure de donnée constituée de nœuds.
Le sommet de l'arbre s'appelle la racine.
Le nœud B situé sous un nœud A est appelé enfant du nœud A
Un nœud qui ne possède pas d'enfant est appelé feuille.
Les nœuds autre que la racine et les feuilles sont appelés nœuds internes.
Une branche est une suite de nœud consécutifs de la racine vers une feuille.
Dans cet arbre:
On donne l'arbre suivant :
On peut caractériser un arbre par différentes caractéristiques :
On reprend l'arbre de la définition d'un arbre :
On donne l'arbre suivant :
Déterminer l'arité, la taille et la hauteur de cet arbre.
Prenons l'exemple de notre réseaux, imaginons que winapps soit la racine.
Représenter une partie:-) de l'arborescence des répertoires et des fichiers à l'aide d'un arbre.
Arbres binaires
On appelle arbre binaire un arbre d'arité 2.
Les arbres binaires sont constitués de nœuds de 0, 1 ou 2 enfants.
Sous-arbre droit/gauche
Quand un nœud a deux enfants, il possède un sous-arbre gauche et un sous-arbre droit.
Pour un nœud \alpha, on notera :
Parmi les arbres suivants lesquels sont binaires?
Les arbres binaires étant particuliers, on peut calculer un certains nombres de caractéristiques d'un arbre binaire.
La taille d'un arbre B correspond au nombre de ses nœuds, elle est définie par :
On donne l'arbre suivant :
Déterminer la taille de cet arbre.
La hauteur d'un nœud ou la profondeur de x correspond au nombre d'arêtes au dessus x pour revenir à la racine, elle est définie par :
On donne l'arbre suivant :
Déterminer la hauteur des nœuds Bob.
La hauteur d'un arbre B correspond au nombre d'arêtes entre a racine et la feuille la plus éloignée :
On donne l'arbre suivant :
Déterminer la hauteur de cet arbre.
La longueur de cheminement d'un arbre B correspond à la somme des hauteurs de chacun des noeuds. :
On donne l'arbre suivant :
Déterminer la longueur de cheminement de cet arbre.
La longueur de cheminement externe d'un arbre B correspond à la somme des hauteurs de chacune des feuilles :
On donne l'arbre suivant :
Déterminer la longueur de cheminement externe de cet arbre.
La longueur de cheminement interne d'un arbre B correspond à la somme des hauteurs des nœuds internes de B :
On donne l'arbre suivant :
Déterminer la longueur de cheminement interne de cet arbre.
Déterminer une relation entre LC(B), LCE(B) et LCI(B).
La profondeur moyenne d'un arbre B est définie par :
PM(B)=LC(B)/T(B)
On donne l'arbre suivant :
Déterminer la profondeur moyenne de cet arbre.
La profondeur moyenne externe d'un arbre B est définie par :
PME(B)=LCE(B)/NF
On donne l'arbre suivant :
Déterminer la profondeur moyenne externe de cet arbre.
La profondeur moyenne interne d'un arbre B est définie par :
PMI(B)=LCI(B)/(T(B)-NF)
On donne l'arbre suivant :
Déterminer la profondeur moyenne interne de cet arbre.
La longueur de cheminement et la profondeur moyenne seront utiles pour les algorithmes sur les arbres binaires.
On donne l'arbre B suivant :
Déterminer :
Un arbre binaire de recherche est un arbre binaire dans lequel l'étiquette d'un nœud est appelé clé et est un entier. L'arbre binaire vérifie deux propriétés :
Quels sont parmi les arbres proposés ci-dessous les arbres binaires de recherche?
Compléter cet arbre pour que ce soit un arbre binaire de recherche :
Un étiquetage intéressant d'un arbre de recherche est le suivant :
Etiqueter comme l'exemple précédent l'arbre suivant :
On observe que les étiquettes des nœuds de profondeur p sont constituées de p + 1 bits, et sont deux à deux distinctes. On en déduit que toutes les étiquettes des nœuds d’un même arbre sont deux à deux distinctes.
Les étiquettes peuvent être vues comme les écritures de numéros en base 2 : on a ainsi numéroté les différents nœuds de l’arbre.