Ce cours comporte plusieurs pages:
- introduction aux graphes
- cours sur les graphes. Term NSI
- algorithmes de parcours des graphes
- TP sur l’implementation en python des graphes
- TP sur les algorithmes de parcours des graphes (app en ligne)
- algorithme de Dijkstra
- Protocoles de routage
- Arbres
Arbres
Définitions
Un arbre est constitué de noeuds organisés de manière hierarchique: c’est un graphe non orienté, connexe, sans cycle, dans lequel on a choisi un noeud particulier appelé la racine.
Chaque noeud peut être étiqueté par une information.
Un arbre est donc un cas particulier des graphes. Voir la page suivante sur les graphes
Des exemples d’arbres:
- l'arbre généalogique est un bon exemple. Le vocabulaire sur la structure des arbres s’inspire d’ailleurs de la génélogie (père-fils).
- L’arbre représentant les sytèmes de dossiers sur ordinateur (dossiers et sous-dossiers puis fichiers).
- arbre lexicographique : représente un ensemble de mots, comme un dictionnaire, où chaque noeud est une lettre. Les prefixes communs à plusieurs mots n’apparaissent qu’une seule fois dans l’arbre:
- arbre représentant des expressions arithmétiques
Les arbres sont très utilisés en informatique, d’abord parce que les données sont souvent hierarchisées, et se prêtent bien à cette structure. Mais aussi parce que l’accès à ces données est alors plus efficace: la recherche d’une valeur se fait en O(log(n)) dans le cas moyen, où n est la taille de l’arbre.
Caractéristiques d’un arbre
- Dans un arbre, chaque valeur est stockée dans un nœud. On appelle parfois cette valeur une clé.
- Les nœuds sont connectés par des arêtes, ou branches qui représentent une relation de type “parent (prédécesseur est le terme exact) – fils”.
- Chaque noeud ne possède qu'un seul noeud parent (sauf le noeud racine).
- La racine est le seul nœud qui n’a pas de prédécesseur.
- Les nœuds qui n’ont pas de fils sont appelés des feuilles.
- Des nœuds qui ont le même père sont appelés des frères.
- Un sous-arbre c’est une portion de l’arbre. C’est une notion utile pour la recursivité.
- Le niveau d’un nœud est la distance qui le sépare de la racine… Sachant que le niveau de la racine est 0 et que le niveau d’un nœud quelconque c’est 1+ le niveau de son père.
- La hauteur d’un arbre, ou sa profondeur est égale au niveau (à la profondeur) du noeud le plus profond. Selon la convention proposée ici (le niveau de la racine vaut 0), la hauteur correspond aussi au plus grand nombre de branches depuis la racine jusqu’à l’une de ses feuilles.
- Le degré d’un arbre est egal au plus grand des degrés de ses noeuds.
- Un arbre de degré égal à 1 est … une liste.
- La taille d’un arbre est son nombre de noeuds.
Arbres binaires
- Arbre binaire: arbre de degré égal à 2. Chaque noeud a au plus 2 fils: le fils droit et le fils gauche.
- Arbre binaire équilibré: pour chaque noeud interne, les sous-arbres gauche et droit ont une même hauteur (ou qui diffère d’une unité).
- Arbre binaire complet: tous les niveaux de l’arbre sont remplis.
Implémenter en python
On utilisera l’arbre suivant pour l’implémentation en python:
Comme vu pour les graphes, on pourra utiliser des listes imbriquées, un dictionnaire, ou une classe (programmation objet).
Liste
Un noeud peut être représenté par une liste imbriquée [clé,fils gauche,fils droit]
.
Et comme les fils gauche ou fils droit sont des noeuds, on y mettra une nouvelle liste imbriquée [clé,fils gauche,fils droit]
.
Pour les feuilles, la liste s’écrit: [clé,None,None]
.
Le petit arbre suivant peut être représenté par ['r'
,[‘a’,None,None],[‘b’,None,None]]`
Avec l’arbre de taille 9 donné en exemple:
arbre9 = [8,[3,..,..],[10,..,..]]
Question: compléter cette liste.
Classe
La classe suivante va permettre d’implémenter les arbres binaires:
class ArbreBinaire:
def __init__(self, valeur):
self.valeur = valeur
self.fils_gauche = None
self.fils_droit = None
On n’a donné ici que le constructeur, mais il est possible d’y ajouter les méthodes qui permettront de retourner une valeur (getter), ou d’ajouter un noeud (setter); ou encore de déterminer les dimensions de l’arbre.
Avec l’arbre de taille 9 vu plus haut, la classe peut s’utiliser de la manière suivante (avec la notation pointée qui n’est pas recommandée):
racine = ArbreBinaire(8)
noeud1 = ArbreBinaire(3)
noeud2 = ArbreBinaire(10)
noeud3 = ArbreBinaire(1)
...
racine.fils_gauche = noeud1
racine.fils_droit = noeud2
noeud1.fils_gauche = noeud3
...
Ou bien, en supposant que vous ayez ajouté deux méthodes de classe ajoute_fils_gauche
et ajoute_fils_droit
:
racine = ArbreBinaire(8)
noeud1 = ArbreBinaire(3)
noeud2 = ArbreBinaire(10)
noeud3 = ArbreBinaire(1)
...
racine.ajoute_fils_gauche(noeud1)
racine.ajoute_fils_droit(noeud2)
noeud1.ajoute_fils_gauche(noeud3)
Parcours
Definition: Un parcours est un algorithme qui appelle une fonction, ou un méthode sur tous les noeuds d’un arbre.
L'ordre sur les noeuds dans lequel la méthode est appelée doit être fixé. Il y a plusieurs choix, qui diffèrent par la seule position de l’instruction Afficher clef [ r ]
L’algorithme opère alors un traitement sur chacune des clés de l’arbre, dans un ordre choisi. Ici, on cherche à Afficher la clef.
Mais on peut remplacer cette instruction par un traitement sur les valeurs.
Parcours postfixe
ParcoursPostfixe ( Arbre binaire T de racine r )
ParcoursPostfixe(Arbre de racine fils_gauche[r])
ParcoursPostfixe(Arbre de racine fils_droit[r])
Afficher clef [ r ]
Parcours préfixe
ParcoursPréfixe ( Arbre binaire T de racine r )
Afficher clef [ r ]
ParcoursPréfixe(Arbre de racine fils_gauche[r])
ParcoursPréfixe(Arbre de racine fils_droit[r])
Parcours infixe
ParcoursInfixe ( Arbre binaire T de racine r )
ParcoursInfixe(Arbre de racine fils_gauche[r])
Afficher clef [ r ]
ParcoursInfixe(Arbre de racine fils_droit[r])
Travaux pratiques
Sur Capytale
Sur Google Colab
- telecharger le fichier module hierarchyP (faire un clic droit et enregistrer sous…)
- utiliser le lien suivant pour acceder au notebook colab
Notebook avec un IDE local
- lien alternatif: télécharger une version locale du notebook (clic droit et enregistrer sous…)
- correction du notebook colab en ligne
Liens
- cours de l’Université Paris Sud: Lien