forked from onlybooks/java-algorithm-interview
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathP52_1.java
87 lines (77 loc) · 2.92 KB
/
P52_1.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
package ch14;
import datatype.TreeNode;
import java.util.LinkedList;
import java.util.Queue;
public class P52_1 {
// 직렬화
public String serialize(TreeNode root) {
// 예외 처리
if (root == null)
return "";
// 반복 BFS 처리를 위한 큐 선언
Queue<TreeNode> queue = new LinkedList<>();
// 큐에 루트부터 삽입
queue.add(root);
// 직렬화 결과 변수
StringBuilder sb = new StringBuilder();
// 0번 인덱스는 사용하지 않으며 초깃값은 루트 노드의 값
sb.append(String.valueOf("#," + root.val));
// 큐가 모두 비워질 때까지 반복
while (!queue.isEmpty()) {
// 큐에서 노드 추출
TreeNode node = queue.poll();
// 왼쪽 자식 노드가 널이 아니면 큐 삽입
if (node.left != null) {
queue.add(node.left);
sb.append("," + node.left.val);
} else {
sb.append(",#");
}
// 오른쪽 자식 노드가 널이 아니면 큐 삽입
if (node.right != null) {
queue.add(node.right);
sb.append("," + node.right.val);
} else {
sb.append(",#");
}
}
// 문자열로 변환하여 리턴
return sb.toString();
}
// 역직렬화
public TreeNode deserialize(String data) {
// 예외 처리
if (data.equals(""))
return null;
// 콤마(,) 기준으로 자른 문자열 배열 선언
String[] nodes = data.split(",");
// 인덱스 1번이 루트
TreeNode root = new TreeNode(Integer.parseInt(nodes[1]));
// 직렬화와 동일하게 BFS로 역직렬화 처리 위한 큐 선언
Queue<TreeNode> queue = new LinkedList<>();
// 큐에 루트부터 추가
queue.add(root);
// 루트를 제외하고 인덱스 2번부터 시작
int index = 2;
// 큐가 모두 비워질 때까지 반복
while (!queue.isEmpty()) {
// 큐에서 노드 추출
TreeNode node = queue.poll();
// 해당 인덱스가 #이 아니면 왼쪽 자식 노드로 설정하고 큐에 추가
if (!nodes[index].equals("#")) {
node.left = new TreeNode(Integer.parseInt(nodes[index]));
queue.add(node.left);
}
// 항상 좌/우 세트로 구성되므로 한 번 더 진행
index += 1;
// 해당 인덱스가 #이 아니면 오른쪽 자식 노드로 설정하고 큐에 추가
if (!nodes[index].equals("#")) {
node.right = new TreeNode(Integer.parseInt(nodes[index]));
queue.add(node.right);
}
index += 1;
}
// 루트 노드를 결과로 리턴
return root;
}
}