
hauteur[x] = (0si xest externe ;
1 + maxy∈x.children hauteur[y]
niveau[x] = (0si xest la racine (x.parent =null) ;
1 + niveau[x.parent]sinon
niveau 0
niveau 1
niveau 2
niveau 3
Un arbre binaire complet de hau-
teur h: il y a 2inœuds `
a chaque ni-
veau i= 0, . . . , h −1. On «remplit»
les niveaux de gauche `
a droit.
Th´
eor`
eme 8.2. Un arbre binaire `
annœuds externes contient (n−1) nœuds internes.
Th´
eor`
eme 8.3. La hauteur hd’un arbre binaire `
annœuds internes est born´
ee par lg(n+ 1)≤h≤n.
D´
emonstration. Un arbre de hauteur h= 0 ne contient qu’un seul nœud externe (n= 0), et les
bornes sont correctes. Pour h > 0, on d´
efinit nkcomme le nombre de nœuds internes au niveau k=
0,1,2, . . . , h −1(il n’y a pas de nœud interne au niveau h). On a n=Ph−1
k=0 nk. Comme nk≥1
pour tout k= 0, . . . , h −1, on a que n≥Ph−1
k=0 1 = h. Pour une borne sup´
erieure, on utilise que
n0= 1, et que nk≤2nk−1pour tout k > 0. En cons´
equence, n≤Ph−1
k=0 2k= 2h−1, d’o`
u
h≥lg(n+ 1). La preuve montre aussi les arbres extrˆ
emes : une chaˆ
ıne de nœuds pour h=n, et un
arbre binaire complet.
Exercice 8.1. Soit nkle nombre de nœuds avec kenfants dans un arbre ordonn´
e (k= 0,1,2, . . . ).
ID´
emontrer que
n0= 1 + n2+ 2 ·n3+ 3 ·n4+· · · + (d−1) ·nd,
o`
udest le degr´
e maximal dans l’arbre. Notez que Th´
eor`
eme 8.2 est un cas sp´
ecial de cette ´
egalit´
e
avec d= 2.Indice: compter les nœuds deux fois — une fois selon le nombre d’enfants, et une
fois selon le parent. ♠
8.4 Parcours
Un parcours visite tous les nœuds de l’arbre. Dans un parcours pr´
efixe (preorder traversal), chaque
nœud est visit´
e avant que ses enfants soient visit´
es. On calcule ainsi des propri´
et´
es avec r´
ecurrence
vers le parent (comme niveau). Dans un parcours postfixe (postorder traversal), chaque nœud est
visit´
e apr`
es que ses enfants sont visit´
es. On calcule ainsi des propri´
et´
es avec r´
ecurrence vers les enfants
(comme hauteur).
Dans les algorithmes suivants, un nœud externe est null, et chaque nœud interne Nposs`
ede les
variables N.children (si arbre ordonn´
e), ou N.left et N.right (si arbre binaire). L’arbre est stock´
e par
une r´
ef´
erence `
a sa racine root.
Algo PARCOURS-PR ´
EFIXE(x)
1if x6=null then
2«visiter»x
3for y∈x.children do
4 PARCOURS-PR ´
EFIXE(y)
Algo PARCOURS-POSTFIXE(x)
1if x6=null then
2for y∈x.children do
3 PARCOURS-POSTFIXE(y)
4«visiter»x
8.3