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]