Python - Binärer Baum

Baum repräsentiert die Knoten, die durch Kanten verbunden sind. Es ist eine nichtlineare Datenstruktur. Es hat die folgenden Eigenschaften.

  • Ein Knoten ist als Stammknoten markiert.
  • Jeder andere Knoten als der Stamm ist einem übergeordneten Knoten zugeordnet.
  • Jeder Knoten kann eine Arbiatrie-Nummer von Chid-Knoten haben.

Wir erstellen eine Baumdatenstruktur in Python unter Verwendung des zuvor diskutierten Konzept-OS-Knotens. Wir bestimmen einen Knoten als Wurzelknoten und fügen dann weitere Knoten als untergeordnete Knoten hinzu. Unten finden Sie ein Programm zum Erstellen des Stammknotens.

Root erstellen

Wir erstellen einfach eine Knotenklasse und fügen dem Knoten einen Wert zu. Dies wird ein Baum mit nur einem Wurzelknoten.

class Node:

    def __init__(self, data):

        self.left = None
        self.right = None
        self.data = data


    def PrintTree(self):
        print(self.data)

root = Node(10)

root.PrintTree()

Wenn der obige Code ausgeführt wird, wird das folgende Ergebnis erzeugt:

10

Einfügen in einen Baum

Zum Einfügen in einen Baum verwenden wir dieselbe oben erstellte Knotenklasse und fügen eine Einfügemethode hinzu. Die Einfügemethode vergleicht den Wert des Knotens mit dem übergeordneten Knoten und beschließt, ihn als linken oder rechten Knoten hinzuzufügen. Schließlich wird die PrintTree-Methode verwendet, um den Baum zu drucken.

class Node:

    def __init__(self, data):

        self.left = None
        self.right = None
        self.data = data

    def insert(self, data):
# Compare the new value with the parent node
        if self.data:
            if data < self.data:
                if self.left is None:
                    self.left = Node(data)
                else:
                    self.left.insert(data)
            elif data > self.data:
                if self.right is None:
                    self.right = Node(data)
                else:
                    self.right.insert(data)
        else:
            self.data = data

# Print the tree
    def PrintTree(self):
        if self.left:
            self.left.PrintTree()
        print( self.data),
        if self.right:
            self.right.PrintTree()

# Use the insert method to add nodes
root = Node(12)
root.insert(6)
root.insert(14)
root.insert(3)

root.PrintTree()

Wenn der obige Code ausgeführt wird, wird das folgende Ergebnis erzeugt:

3 6 12 14

Einen Baum durchqueren

Der Baum kann durchlaufen werden, indem eine Sequenz festgelegt wird, um jeden Knoten zu besuchen. Wie wir deutlich sehen können, können wir an einem Knoten beginnen und dann zuerst den linken Unterbaum und dann den rechten Unterbaum besuchen. Oder wir können auch zuerst den rechten Unterbaum und dann den linken Unterbaum besuchen. Dementsprechend gibt es unterschiedliche Namen für diese Baumdurchlaufmethoden. Wir untersuchen sie ausführlich in dem Kapitel, in dem die Baumdurchquerungsalgorithmen hier implementiert werden. Tree Traversal-Algorithmen