Insertion dans un ABR (4)

Un arbre binaire est soit vide, représenté en Python par la valeur None, soit un nœud, contenant une étiquette et deux sous-arbres gauche et droit et représenté par une instance de la classe Noeud donnée ci-dessous.

🐍 Script Python
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
class Noeud:
    """Classe représentant un noeud d'un arbre binaire"""
    def __init__(self, etiquette, gauche, droit):
        """Crée un noeud de valeur etiquette avec 
        gauche et droit comme fils."""
        self.etiquette = etiquette
        self.gauche = gauche
        self.droit = droit

def parcours(arbre, liste):
    """parcours récursivement l'arbre en ajoutant les étiquettes
    de ses noeuds à la liste passée en argument en ordre infixe."""
    if arbre != None:
        parcours(arbre.gauche, liste)
        liste.append(arbre.etiquette)
        parcours(arbre.droit, liste)
    return liste

La fonction récursive parcours renvoie la liste des étiquettes des nœuds de l’arbre implé- menté par l’instance arbre dans l’ordre du parcours en profondeur infixe à partir d’une liste vide passée en argument.

Compléter le code de la fonction insere, qui prend en argument un arbre binaire de recherche arbre représenté ainsi et une étiquette cle, non présente dans l’arbre, et qui :

  • renvoie une nouvelle feuille d’étiquette cle s’il est vide ;
  • renvoie l’arbre après l’avoir modifié en insérant cle sinon ;
  • garantit que l’arbre ainsi complété soit encore un arbre binaire de recherche.

Tester ensuite ce code en utilisant la fonction parcours et en insérant successivement des nœuds d’étiquette 1, 4, 6 et 8 dans l’arbre binaire de recherche représenté ci- dessous :

flowchart TD
    A(5) --- B(2)
    A --- C(7)
    B --- D( )
    B --- E(3)
    linkStyle 2 stroke-width:0px;
    style D opacity:0;
Compléter le script ci-dessous

###
# Testsbksl-nlbksl-nla1 = Noeud(5, None, None)bksl-nla1 = insere(a1, 2)bksl-nla1 = insere(a1, 3)bksl-nla1 = insere(a1, 7)bksl-nlassert parcours(a1, []) == [2, 3, 5, 7]bksl-nla1 = insere(a1, 1)bksl-nla1 = insere(a1, 4)bksl-nla1 = insere(a1, 6)bksl-nla1 = insere(a1, 8)bksl-nlassert parcours(a1, []) == [1, 2, 3, 4, 5, 6, 7, 8]bksl-nlbksl-nlbksl-nl# Autres testsbksl-nla2 = a1bksl-nla2 = insere(a2, 10)bksl-nlassert parcours(a2, []) == [1, 2, 3, 4, 5, 6, 7, 8, 10]bksl-nlbksl-nl 5/5
class Noeud:bksl-nl """Classe représentant un noeud d'un arbre binaire"""bksl-nl def py-undpy-undinitpy-undpy-und(self, etiquette, gauche, droit):bksl-nl """Crée un noeud de valeur etiquette avec bksl-nl gauche et droit comme fils."""bksl-nl self.etiquette = etiquettebksl-nl self.gauche = gauchebksl-nl self.droit = droitbksl-nlbksl-nldef parcours(arbre, liste):bksl-nl """parcours récursivement l'arbre en ajoutant les étiquettesbksl-nl de ses noeuds à la liste passée en argument en ordre infixe."""bksl-nl if arbre != None:bksl-nl parcours(arbre.gauche, liste)bksl-nl liste.append(arbre.etiquette)bksl-nl parcours(arbre.droit, liste)bksl-nl return listebksl-nlbksl-nldef insere(arbre, cle):bksl-nl """insere la cle dans l'arbre binaire de recherchebksl-nl représenté par arbre.bksl-nl Retourne l'arbre modifié."""bksl-nl if arbre == None:bksl-nl return Noeud(cle, None, None) # creation d'une feuillebksl-nl else:bksl-nl if ...: bksl-nl arbre.gauche = insere(arbre.gauche, cle)bksl-nl else:bksl-nl arbre.droit = ... bksl-nl return arbrebksl-nlbksl-nlbksl-nldef insere(arbre, cle):bksl-nl """insere la cle dans l'arbre binaire de recherchebksl-nl représenté par arbre.bksl-nl Retourne l'arbre modifié."""bksl-nl if arbre == None:bksl-nl return Noeud(cle, None, None) # creation d'une feuillebksl-nl else:bksl-nl if cle < arbre.etiquette: bksl-nl arbre.gauche = insere(arbre.gauche, cle)bksl-nl else:bksl-nl arbre.droit = insere(arbre.droit, cle) bksl-nl return arbrebksl-nlbksl-nla = Noeud(5, None, None)bksl-nla = insere(a, 2)bksl-nla = insere(a, 3)bksl-nla = insere(a, 7)bksl-nla = insere(a, 1)bksl-nla = insere(a, 4)bksl-nla = insere(a, 6)bksl-nla = insere(a, 8)bksl-nlbksl-nl