Tree(트리)
· 약 3분
트리
- 루트 정점을 제외한 모든 정점은 반드시 하나의 부모 정점을 가진다.
- 정점이 개인 트리는 반드시 개의 간선을 가진다.
- 루트에서 특정 정점으로 가는 경로는 유일하다.
이진트리
- 각 장점이 최대 2개의 자식을 가지는 트리
- 정점이 개인 이진트리의 최악의 경우 높이가 이 될 수 있다.
- 정점 개인 포화 또는 완전 이진 트리의 높이는 logN이다.
- 높이가 인 포화 이진 트리는 개의 정점을 가진다.
- 일반적인 이진 트리를 사용하는 경우는 많지 않고 다른 자료구조에 응 용된다.
예) 이진 탐색 트리, 힙, AVL 트리, 레드 블랙 트리
구현 방법
- 그래프와 마찬가지로 인접 행렬, 인접 리스트 두 가지 방식으로 트리를 표현할 수 있다.
- 배열 혹은 요소에 링크가 2개 존재하는 연결 리스트로 구현할 수 있다.
Linked List로 트리 구현
javascript
class Node {
constructor(value) {
this.value = value;
this.left = null;
this.right = null;
}
}
class Queue {
constructor() {
this.head = null;
this.tail = null;
this.size = 0;
}
enqueue(value) {
const newNode = new Node(value);
if (!this.head) {
this.head = this.tail = newNode;
} else {
this.tail.next = newNode;
this.tail = newNode;
}
this.size += 1;
}
dequeue() {
const value = this.head.value;
this.head = this.head.next;
this.size -= 1;
return value;
}
peek() {
return this.head.value;
}
}
class Tree {
constructor(node) {
this.root = node;
}
display() {
const queue = new Queue();
queue.enqueue(this.root);
while (queue.size) {
const currentNode = queue.dequeue();
console.log(currentNode.value);
if (currentNode.left) queue.enqueue(currentNode.left);
if (currentNode.right) queue.enqueue(currentNode.right);
}
}
}
const tree = new Tree(new Node(9));
tree.root.left = new Node(3);
tree.root.right = new Node(8);
tree.root.left.left = new Node(2);
tree.root.left.right = new Node(5);
tree.root.right.right = new Node(7);
tree.root.left.right.right = new Node(4);
tree.display();
powershell
9
3
8
2
5
7
4