Python-트리 탐색 알고리즘
순회는 트리의 모든 노드를 방문하는 프로세스이며 해당 값도 인쇄 할 수 있습니다. 모든 노드는 에지 (링크)를 통해 연결되기 때문에 항상 루트 (헤드) 노드에서 시작합니다. 즉, 트리의 노드에 무작위로 액세스 할 수 없습니다. 나무를 횡단하는 데 사용하는 세 가지 방법이 있습니다.
- 순회 순회
- 순회 선주문
- 주문 후 순회
순회 순회
이 순회 방법에서는 왼쪽 하위 트리를 먼저 방문한 다음 루트를 방문하고 나중에 오른쪽 하위 트리를 방문합니다. 우리는 항상 모든 노드가 하위 트리 자체를 나타낼 수 있음을 기억해야합니다.
아래 파이썬 프로그램에서 Node 클래스를 사용하여 루트 노드와 왼쪽 및 오른쪽 노드에 대한 자리 표시자를 만듭니다. 그런 다음 데이터를 트리에 추가하는 삽입 함수를 만듭니다. 마지막으로 Inorder 순회 논리는 빈 목록을 만들고 루트 또는 부모 노드가 뒤 따르는 왼쪽 노드를 먼저 추가하여 구현됩니다. 마지막으로 왼쪽 노드가 추가되어 Inorder 순회를 완료합니다. 이 프로세스는 모든 노드가 순회 될 때까지 각 하위 트리에 대해 반복됩니다.
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))
위의 코드가 실행되면 다음과 같은 결과가 생성됩니다.
[10, 14, 19, 27, 31, 35, 42]
순회 선주문
이 순회 방법에서는 루트 노드를 먼저 방문한 다음 왼쪽 하위 트리, 마지막으로 오른쪽 하위 트리를 방문합니다.
아래 파이썬 프로그램에서 Node 클래스를 사용하여 루트 노드와 왼쪽 및 오른쪽 노드에 대한 자리 표시자를 만듭니다. 그런 다음 데이터를 트리에 추가하는 삽입 함수를 만듭니다. 마지막으로 빈 목록을 만들고 루트 노드를 먼저 추가 한 다음 왼쪽 노드를 추가하여 사전 주문 순회 논리를 구현합니다. 마지막으로 오른쪽 노드가 추가되어 선주문 순회를 완료합니다. 이 프로세스는 모든 노드가 순회 될 때까지 각 하위 트리에 대해 반복됩니다.
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))
위의 코드가 실행되면 다음과 같은 결과가 생성됩니다.
[27, 14, 10, 19, 35, 31, 42]
주문 후 순회
이 순회 방법에서 루트 노드는 마지막으로 방문하므로 이름이됩니다. 먼저 왼쪽 하위 트리, 오른쪽 하위 트리, 마지막으로 루트 노드를 순회합니다.
아래 파이썬 프로그램에서 Node 클래스를 사용하여 루트 노드와 왼쪽 및 오른쪽 노드에 대한 자리 표시자를 만듭니다. 그런 다음 데이터를 트리에 추가하는 삽입 함수를 만듭니다. 마지막으로 빈 목록을 만들고 왼쪽 노드를 먼저 추가 한 다음 오른쪽 노드를 추가하여 후 순서 순회 논리를 구현합니다. 마지막으로 루트 또는 상위 노드가 추가되어 주문 후 순회를 완료합니다. 이 프로세스는 모든 노드가 순회 될 때까지 각 하위 트리에 대해 반복됩니다.
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))
위의 코드가 실행되면 다음과 같은 결과가 생성됩니다.
[10, 19, 14, 31, 42, 35, 27]