4 Arbres bicolores et arbres 2-3-4
4.1 Arbres bicolores
4.1.1 D´efinition
Un arbre bicolore de recherche est un arbre binaire de recherche compl´et´e dans lequel tout sommet
poss`ede une couleur (blanc ou rouge) et tout nœud interne poss`ede une cl´e et qui v´erifie :
•les feuilles sont blanches (et ne poss`edent pas de cl´e)
•le p`ere d’un sommet rouge est blanc
•les chemins issus d’un mˆeme sommet et se terminant en une feuille ont le mˆeme nombre
de sommets blancs.
4.1.2 Primitives
Pour manipuler les arbres bicolores, on dispose des primitives habituelles sur les arbres binaires :
ArbreVide : −>arbre binaire
ArbreVide() renvoie un arbre vide
ArbreBinaire : ´el´ement ×arbre binaire ×arbre binaire −>arbre binaire
ArbreBinaire(x,G,D) renvoie l’arbre binaire dont la racine a pour contenu l’´el´ement x
et dont les sous-arbres gauche et droit sont respectivement G et D
EstArbreVide : arbre binaire −>bool´een
EstArbreVide(T) renvoie VRAI ssi T est un arbre binaire vide
Racine : arbre binaire −>´el´ement
Racine(T) renvoie le contenu de la racine de l’arbre binaire T
SousArbreGauche : arbre binaire −>arbre binaire
SousArbreGauche(T) renvoie une copie du sous-arbre gauche de l’arbre binaire T
SousArbreDroit : arbre binaire −>arbre binaire
SousArbreDroit(T) renvoie une copie du sous-arbre droit de l’arbre binaire T
et de primitives sp´ecifiques aux arbres bicolores :
FeuilleBlanche : −>arbre binaire
FeuilleBlanche() renvoie l’arbre binaire r´eduit `a une feuille de couleur c blanche
ArbreBinaire : cl´e ×couleur ×arbre binaire ×arbre binaire −>arbre binaire
ArbreBinaire(a,c,G,D) renvoie l’arbre binaire dont la racine a pour cl´e a et
pour couleur c et dont les sous-arbres gauche et droit sont respectivement G et D
EstFeuille : arbre binaire −>bool´een
EstFeuille(T) renvoie VRAI ssi T est un arbre binaire r´eduit `a une feuille
CleRacine : arbre binaire −>cl´e
CleRacine(T) renvoie la cl´e de la racine de T
CouleurRacine : arbre binaire −>couleur
CouleurRacine(T) renvoie la couleur de la racine de T
ModifierCouleur : arbre binaire ×couleur −>Rien
ModifierCouleur(T,c) remplace par c la couleur de la racine de l’arbre binaire T
4.2 Arbres 2-3-4
1. Rappeler les r`egles d’´eclatement d’un 4-nœud dans un arbre 2-3-4, lorsque les ´eclatements
se font `a la descente.
2. Construire par adjonctions successives un arbre 2-3-4 contenant les cl´es 8, 3, 2, 4, 1, 15,
10, 9, 11, 7, 6, 13, 12, 5, 14, 16, 17. On nommera cet arbre A-ex1.
4