seunghyun Note
Tree traversal(2) with JS 본문
728x90
반응형
깊이 우선 (DFS)
- preorder, inorder, postorder
- 재귀함수 사용해서 문제 해결하기
//Node를 생성한다.
class Node {
constructor(value) {
this.value = value;
this.left = null;
this.right = null;
}
}
//BST
class BinarySearchTree {
constructor() {
this.root = null;
}
insert(value) {
var newNode = new Node(value);
if (this.root === null) {
this.root = newNode;
return this;
}
var current = this.root;
while (true) {
if (value === current.value) return undefined;
if (value < current.value) {
if (current.left === null) {
current.left = newNode;
return this;
}
current = current.left;
} else {
if (current.right === null) {
current.right = newNode;
return this;
}
current = current.right;
}
}
}
find(value) {
if (this.root === null) return false;
var current = this.root,
found = false;
while (current && !found) {
if (value < current.value) {
current = current.left;
} else if (value > current.value) {
current = current.right;
} else {
found = true;
}
}
if (!found) return undefined;
return current;
}
contains(value) {
if (this.root === null) return false;
var current = this.root,
found = false;
while (current && !found) {
if (value < current.value) {
current = current.left;
} else if (value > current.value) {
current = current.right;
} else {
return true;
}
}
return false;
}
BFS() {
var node = this.root,
data = [],
queue = [];
queue.push(node);
while (queue.length) {
node = queue.shift();
data.push(node.value);
if (node.left) queue.push(node.left);
if (node.right) queue.push(node.right);
}
return data;
}
//DFS 순회
DFSPreOrder() {
var data = [];
function traverse(node) {
data.push(node.value);
console.log(node.value);
if (node.left) traverse(node.left);
if (node.right) traverse(node.right);
}
traverse(this.root);
return data;
}
DFSPostOrder() {
var data = [];
function traverse(node) {
if (node.left) traverse(node.left);
if (node.right) traverse(node.right);
data.push(node.value);
console.log(node.value);
}
traverse(this.root);
return data;
}
DFSInOrder() {
var data = [];
function traverse(node) {
if (node.left) traverse(node.left);
data.push(node.value);
console.log(node.value);
if (node.right) traverse(node.right);
}
traverse(this.root);
return data;
}
}
var tree = new BinarySearchTree();
tree.insert(10);
tree.insert(6);
tree.insert(15);
tree.insert(3);
tree.insert(8);
tree.insert(20);
console.log("DFS Preorder");
tree.DFSPreOrder();
console.log("DFS PostOrder");
tree.DFSPostOrder();
console.log("DFS Inorder");
tree.DFSInOrder();
728x90
반응형
'코딩테스트 > 코테를 위한 알고리즘 & 자료구조 정리' 카테고리의 다른 글
Binary Heaps with JS (0) | 2024.02.23 |
---|---|
Tree traversal(1) with JS (0) | 2024.02.14 |
BST(Binary Search Tree) with JS (0) | 2024.02.07 |
Queue with JS (1) | 2024.01.30 |
Stack with JS (0) | 2024.01.25 |