Python - Algoritma Penjelajah Pohon

Traversal adalah proses untuk mengunjungi semua node dari pohon dan dapat mencetak nilainya juga. Sebab, semua node terhubung melalui edge (tautan) kami selalu memulai dari node root (kepala). Artinya, kita tidak dapat mengakses node di pohon secara acak. Ada tiga cara yang kami gunakan untuk melintasi pohon -

  • In-order Traversal
  • Praorder Traversal
  • Traversal pasca pesanan

In-order Traversal

Dalam metode traversal ini, sub-pohon kiri dikunjungi terlebih dahulu, kemudian akar dan kemudian sub-pohon kanan. Kita harus selalu ingat bahwa setiap node dapat mewakili subpohon itu sendiri.

Dalam program python di bawah ini, kami menggunakan kelas Node untuk membuat placeholder untuk node root serta node kiri dan kanan. Kemudian kami membuat fungsi sisipkan untuk menambahkan data ke pohon. Akhirnya logika traversal inorder diimplementasikan dengan membuat daftar kosong dan menambahkan node kiri terlebih dahulu diikuti oleh root atau node induk. Akhirnya node kiri ditambahkan untuk menyelesaikan traversal Inorder. Harap dicatat bahwa proses ini diulangi untuk setiap sub-pohon sampai semua node dilintasi.

class Node:

    def __init__(self, data):

        self.left = None
        self.right = None
        self.data = data
# Insert Node
    def insert(self, data):

        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()

# Inorder traversal
# Left -> Root -> Right
    def inorderTraversal(self, root):
        res = []
        if root:
            res = self.inorderTraversal(root.left)
            res.append(root.data)
            res = res + self.inorderTraversal(root.right)
        return res

root = Node(27)
root.insert(14)
root.insert(35)
root.insert(10)
root.insert(19)
root.insert(31)
root.insert(42)
print(root.inorderTraversal(root))

Ketika kode di atas dijalankan, itu menghasilkan hasil sebagai berikut -

[10, 14, 19, 27, 31, 35, 42]

Praorder Traversal

Dalam metode traversal ini, simpul akar dikunjungi pertama, kemudian subpohon kiri dan terakhir subpohon kanan.

Dalam program python di bawah ini, kami menggunakan kelas Node untuk membuat placeholder untuk node root serta node kiri dan kanan. Kemudian kami membuat fungsi sisipkan untuk menambahkan data ke pohon. Akhirnya logika traversal Pre-order diimplementasikan dengan membuat daftar kosong dan menambahkan node root terlebih dahulu diikuti oleh node kiri. Akhirnya node kanan ditambahkan untuk menyelesaikan traversal Pre-order. Harap dicatat bahwa proses ini diulangi untuk setiap sub-pohon sampai semua node dilintasi.

class Node:

    def __init__(self, data):

        self.left = None
        self.right = None
        self.data = data
# Insert Node
    def insert(self, data):

        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()

# Preorder traversal
# Root -> Left ->Right
    def PreorderTraversal(self, root):
        res = []
        if root:
            res.append(root.data)
            res = res + self.PreorderTraversal(root.left)
            res = res + self.PreorderTraversal(root.right)
        return res

root = Node(27)
root.insert(14)
root.insert(35)
root.insert(10)
root.insert(19)
root.insert(31)
root.insert(42)
print(root.PreorderTraversal(root))

Ketika kode di atas dijalankan, itu menghasilkan hasil sebagai berikut -

[27, 14, 10, 19, 35, 31, 42]

Traversal pasca pesanan

Dalam metode traversal ini, simpul akar dikunjungi terakhir, karena itulah namanya. Pertama kita melintasi subtree kiri, lalu subtree kanan dan akhirnya simpul root.

Dalam program python di bawah ini, kami menggunakan kelas Node untuk membuat placeholder untuk node root serta node kiri dan kanan. Kemudian kami membuat fungsi sisipkan untuk menambahkan data ke pohon. Akhirnya logika traversal Post-order diimplementasikan dengan membuat daftar kosong dan menambahkan node kiri terlebih dahulu diikuti oleh node kanan. Akhirnya root atau node induk ditambahkan untuk menyelesaikan traversal Post-order. Harap dicatat bahwa proses ini diulangi untuk setiap sub-pohon sampai semua node dilintasi.

class Node:

    def __init__(self, data):

        self.left = None
        self.right = None
        self.data = data
# Insert Node
    def insert(self, data):

        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()

# Postorder traversal
# Left ->Right -> Root
    def PostorderTraversal(self, root):
        res = []
        if root:
            res = self.PostorderTraversal(root.left)
            res = res + self.PostorderTraversal(root.right)
            res.append(root.data)
        return res

root = Node(27)
root.insert(14)
root.insert(35)
root.insert(10)
root.insert(19)
root.insert(31)
root.insert(42)
print(root.PostorderTraversal(root))

Ketika kode di atas dijalankan, itu menghasilkan hasil sebagai berikut -

[10, 19, 14, 31, 42, 35, 27]