TD07 Arbres1 Correction

Télécharger au format pdf ou txt
Télécharger au format pdf ou txt
Vous êtes sur la page 1sur 7

Les arbres binaires (1/2)

TD7 Structures de données arborescentes – Spécialité NSI Terminale

Exercice 1. Dessine-moi un arbre 🖉


Le tableau ci-dessous décrit un arbre :
Père Fils gauche Fils droit
A B C
B D E
C F G
D H I
G J K
F L

1. Représenter l'arbre correspondant.

2. Quelle est la hauteur de cet arbre ?


D’après la définition du cours : nombre de nœuds depuis la racine jusqu’à la feuille la plus
éloignée : h = 4.
On trouve également une autre définition de la hauteur où on ne compte pas le nœud racine. Dans
ce cas, h = 3.
3. Quelle est la taille de cet arbre (nombre de nœuds) ? Combien a-t-il de feuilles ?
12 nœuds et 6 feuilles
4. Cet arbre est-il binaire ? complet ?
Cet arbre est binaire car aucun nœud n’a plus de deux fils. Il n’est pas complet car tous les
niveaux ne sont pas remplis.

Terminale NSI – TD07. Les arbres binaires (1/2) – p 1/7


Exercice 2. Avec un dictionnaire (sujet de l’épreuve pratique)
Dans cet exercice, un arbre binaire de caractères est stocké sous la forme d’un dictionnaire où les clefs
sont les caractères des nœuds de l’arbre et les valeurs, pour chaque clef, la liste des caractères des fils
gauche et droit du nœud.
Par exemple, l’arbre :

est stocké dans :


a = {'F':['B','G'], 'B':['A','D'], 'A':['',''], 'D':['C','E'], 'C':['',''], \
'E':['',''], 'G':['','I'], 'I':['','H'], 'H':['','']}
Écrire une fonction récursive taille prenant en paramètres un arbre binaire arbre sous la forme d’un
dictionnaire et un caractère lettre qui est la valeur du sommet de l’arbre, et qui renvoie la taille de
l’arbre à savoir le nombre total de nœuds.
On pourra distinguer les 4 cas où les deux « fils » du nœud sont '', le fils gauche seulement est '', le fils
droit seulement est '', aucun des deux fils n’est ''.
Exemple :
>>> taille(a,'F')
9
>>> taille(a,'B')
5
>>> taille(a,'H')
1
>>> taille(a,'I')
2

def taille(arbre, sommet):


if arbre[sommet]==['','']:
return 1
elif arbre[sommet][0]=='':
return 1 + taille(arbre, arbre[sommet][1])
elif arbre[sommet][1]=='':
return 1 + taille(arbre, arbre[sommet][0])
else:
return 1 + taille(arbre, arbre[sommet][0]) + taille(arbre, arbre[sommet][1])

Terminale NSI – TD07. Les arbres binaires (1/2) – p 2/7


Exercice 3. Un arbre dans un tableau 🖉
Comme vous l’avez sans doute constaté, il est difficile de représenter un arbre sur une seule ligne. Une
solution est de représenter l’arbre sous forme d’un tableau de tableaux.

Cet arbre se représente par le tableau : ['A',['B',[],[]],['C',[],[]]]

Écrire le tableau représentant l’arbre ci-dessous :

['A',['B',['D',[],[]],['E',[],[]]],['C',['F',[],[]],[]]]

Exercice 4. Extrait du sujet 0 (écrit) 🖉


Dans cet exercice, on utilisera la convention suivante : la hauteur d’un arbre binaire ne comportant qu’un
nœud est 1.
1. Déterminer la taille et la hauteur de l’arbre binaire suivant :

B E

C D F

G H I

D’après la définition donnée dans cet exercice, qui est en accord avec celle du cours, la hauteur
de cet arbre est h = 4.
La taille correspond au nombre de nœuds soit 9.
2. On décide de numéroter en binaire les nœuds d’un arbre binaire de la façon suivante :
• la racine correspond à 1 ;
• la numérotation pour un fils gauche s’obtient en ajoutant le chiffre 0 à droite au
numéro de son père ;
• la numérotation pour un fils droit s’obtient en ajoutant le chiffre 1 à droite au numéro
de son père ;
Par exemple, dans l’arbre ci-dessous, on a utilisé ce procédé pour numéroter les nœuds A, B, C, E et F.

Terminale NSI – TD07. Les arbres binaires (1/2) – p 3/7


A :1

B :10 E : 11

C : 100 D:? F:110

G:? H :? I :?

2.1. Dans l’exemple précédent, quel est le numéro en binaire associé au nœud G ?
G : 1010
2.2. Quel est le nœud dont le numéro en binaire vaut 13 en décimal ?
1310 = 11012 ⇒ I
2.3. En notant h la hauteur de l’arbre, sur combien de bits seront numérotés les nœuds les plus
en bas ?
Sur 4 bits car h = 4.

3. Justifier que pour tout arbre de hauteur h et de taille n ⩾ 2, on a :


h ⩽ n ⩽ 2h – 1

• On trouve le nombre minimal de nœuds dans un arbre linéaire où nmin = h


• Le nombre de nœuds est maximal dans un arbre parfait : nmax = 1 + 2 + 4 + … + 2h—1
nmax est donc la somme des n premiers termes d’une suite géométrique de premier terme 1 et
de raison 2.
h
2 -1
On montre que 1 + 2 + 4 + … + 2h—1 = = 2h – 1 ⇒ nmax = 2h—1 – 1
2 -1
• On en déduit : h ⩽ n ⩽ 2h – 1
4. Un arbre binaire est dit complet si tous les niveaux de l’arbre sont remplis.

On décide de représenter un arbre binaire complet par un tableau de taille n + 1, où n est la taille de
l’arbre, de la façon suivante :
• La racine a pour indice 1 ;
• Le fils gauche du nœud d’indice i a pour indice 2 × i ;
• Le fils droit du nœud d’indice i a pour indice 2 × i + 1 ;
• On place la taille n de l’arbre dans la case d’indice 0.
4.1. Déterminer le tableau qui représente l’arbre binaire complet de l’exemple précédent.
En appliquant les règles du sujet :
[15, A, B , C , D, E , F, G , H , I , J , K , L, M , N , O]
4.2. On considère le père du nœud d’indice i avec i ⩾ 2. Quel est son indice dans le tableau ?
En notant p l’indice du père : 2p = i si fils gauche ou 2p + 1 = i si fils droit.
i i−1
D’où, si i pair : p = et si i impair : p =
2 2

Terminale NSI – TD07. Les arbres binaires (1/2) – p 4/7


Exercice 5. La classe Noeud
On veut implémenter l’arbre ci-dessous :

à l’aide de la classe Noeud ainsi définie :


class Noeud:
def __init__(self ,valeur):
self.valeur = valeur
self.gauche = None
self.droit = None
def _ _ str_ _ (self):
return str(self.valeur)

Attention : la classe Noeud est différente de celle du cours.


Dans cette arbre, les valeurs ne peuvent être que des entiers.
A partir de la questions 2, toutes les fonctions sont récursives.

1. Implémenter l’arbre représenté ci-dessus en utilisant la classe Noeud.


Le nœud 1 sera appelé racine.
Solution possible :
racine = Noeud(1)
racine.gauche = Noeud(2)
racine.gauche.gauche = Noeud(3)
racine.gauche.gauche.gauche = Noeud(7)
racine.gauche.gauche.droit = Noeud(4)
racine.gauche.droit = Noeud(5)
racine.gauche.droit.gauche = Noeud(3)
racine.droit = Noeud(3)
racine.droit.gauche = Noeud(6)
racine.droit.gauche.gauche = Noeud(5)
Il existe d’autres solutions, comme par exemple de nommer chaque nœud avant de le « relier » au
père.
2. Créer une fonction affiche(a) qui reçoit le nœud racine de l’arbre en paramètre et affiche l’arbre
avec des parenthèses autour du nœud et de ses sous arbres.
On pourra agréablement s’inspirer très fortement du code du cours.
>>> affiche(racine.gauche.gauche)
( ( 7 ) 3 ( 4 ) )
>>> affiche(racine)
( ( ( ( 7 ) 3 ( 4 ) ) 2 ( ( 3 ) 5 ) ) 1 ( ( ( 5 ) 6 ) 3 ) )

Terminale NSI – TD07. Les arbres binaires (1/2) – p 5/7


def affiche(a):
if a is None:
return
print ("(", end=" ")
affiche(a.gauche)
print (a.valeur, end=" ")
affiche(a.droit)
print (")", end=" ")
3. Écrire une fonction tailleArbre(a) qui reçoit le nœud racine de l’arbre en paramètre et renvoie
la taille de l’arbre (nombre de nœuds).
>>> tailleArbre(racine)
10
def tailleArbre(a):
if a is None:
return 0
else:
return 1 + tailleArbre(a.gauche) + tailleArbre(a.droit)

4. Ajouter une fonction hauteur(a) qui reçoit le nœud racine de l’arbre en paramètre et renvoie la
hauteur de l’arbre.
>>> hauteur(racine)
4
def hauteur(a):
if a is None:
return 0
else:
return 1 + max(hauteur(a.gauche), hauteur(a.droit))

5. Créer une fonction feuilles(a) qui reçoit le nœud racine de l’arbre en paramètre et renvoie le
nombre de feuilles dans l’arbre.
>>> feuilles(racine)
4
def feuilles(a):
if a is None:
return 0
if a.gauche is None and a.droit is None :
return 1
else:
return feuilles(a.gauche) + feuilles(a.droit)

Terminale NSI – TD07. Les arbres binaires (1/2) – p 6/7


6. Compléter ce magnifique code d’une fonction cherche(a, x) qui reçoit le nœud racine de
l’arbre et une entier x en paramètres et renvoie le nombre d’occurrences de x dans l’arbre.
>>> cherche(racine,3)
3
>>> cherche(racine,7)
1
>>> cherche(racine,9)
0
def cherche(a, x):
if a is None:
return 0
else:
if a.valeur==x:
return 1 + cherche(a.gauche,x) + cherche(a.droit,x)
else:
return cherche(a.gauche,x) + cherche(a.droit,x)

Terminale NSI – TD07. Les arbres binaires (1/2) – p 7/7

Vous aimerez peut-être aussi