4) Montrer que le nombre de fils d’un sommet est ´egal au nombre de ”1” qui suivent le dernier
”0” dans l’´ecriture binaire de son num´ero.
Etant donn´e un entier n, soit :
n=X
i≥0
bi2i;bi∈ {0,1}
sa d´ecomposition en base 2, soit In={i|bi= 1}, et soit ν(n) = Card(In). La forˆet binomiale
d’ordre nest l’ensemble Fn={Bi|i∈In}. La composante d’indice ide Fnest Bi, si i∈In, et
∅sinon.
5) Montrer que Fnan−ν(n) arrˆetes.
Une file binomiale est une forˆet binomiale dont chaque sommet xest muni d’une cl´e c(x), v´erifiant :
si yest fils de x, alors c(y)> c(x).
6) Montrer que la recherche du sommet de cl´e minimale dans une file binomiale Fnpeut se faire
en ν(n)−1 comparaisons.
Soient Fnet Fn′deux files binomiales ayant des ensembles de cl´es disjoints. On d´efinit l’op´eration
UN ION (Fn, Fn′) qui retourne une file binomiale ayant pour cl´es l’union des ensembles de cl´es
comme suit :
– Si n=n′= 2p, alors Fn={Bp},Fn′={B′
p}, et U N ION (Bp, B′
p) est l’arbre Bp+1 pour
lequel Bg
p=Bpet Bd
p=B′
psi la cl´e de la racine de Bpest plus grande que la cl´e de la racine
de B′
pet l’inverse dans le cas contraire.
– Dans le cas g´en´eral, on proc`ede en commen¸cant avec les composantes d’indice minimal des
deux files, et en construisant une suite d’arbres report. L’arbre report R0est vide, et `a l’´etape
k > 0, l’arbre report Rkest soit vide, soit un arbre binomial d’ordre k. Etant donn´es l’arbre
report Rk, la composante Ckde Fnet la composante C′
kde Fn′, on d´efinit la composante
C′′
kd’ordre k de U NION (Fn, Fn′) et l’arbre report Rk+1 comme suit :
1. Si Rk=Ck=C′
k=∅, alors C′′
k=Rk+1 =∅;
2. Si seule l’une des trois op´erandes est non vide, elle devient C′′
k, et Rk+1 =∅;
3. Si deux op´erandes sont non vides, alors C′′
k=∅et Rk+1 est l’union des deux op´erandes ;
4. Si les trois op´erandes sont non vides, l’une devient C′′
ket Rk+1 est l’union des deux
autres op´erandes ;
7) En supposant que l’union de deux arbres binomiaux de mˆeme ordre prend un temps constant,
donner une majoration logarithmique en net n′du temps de U N ION (Fn, Fn′).
8) Proposer une structure de donn´ees qui permet de faire l’union de deux arbres binomiaux en
temps constant.
9) Montrer que le nombre de comparaisons de cl´es pour construire U N ION (Fn, Fn′) est ν(n) +
ν(n′)−ν(n+n′).
10) Montrer comment l’insertion, dans une file binomiale, d’une cl´e qui n’y figure pas d´ej`a peut
se ramener `a une union.
3