1 Star 0 Fork 0

珂珂/Algorithm

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
SerialTree.java 3.08 KB
一键复制 编辑 原始数据 按行查看 历史
珂珂 提交于 2021-07-17 17:12 . 2021/7/17 update
package zuo.chapter3;
import java.util.LinkedList;
import java.util.Queue;
/**
* @author keboom
* @date 2021/5/6
*/
public class SerialTree {
/**
* 通过先序遍历来序列化
* @param head
* @return
*/
public String serialByPre(TreeNode head) {
if (head == null) {
return "#!";
}
String res = head.value + "!";
res += serialByPre(head.left);
res += serialByPre(head.right);
return res;
}
/**
* 先序遍历反序列化
* @param preStr
* @return
*/
public TreeNode reconByPreString(String preStr) {
String[] values = preStr.split("!");
LinkedList<String> queue = new LinkedList<>();
for (int i = 0; i < values.length; i++) {
queue.offer(values[i]);
}
return reconPreOrder(queue);
}
/**
* 正好模拟了先序遍历的过程
* @param queue
* @return
*/
private TreeNode reconPreOrder(Queue<String> queue) {
String value = queue.poll();
if (value.equals("#")) {
return null;
}
TreeNode head = new TreeNode(Integer.valueOf(value));
head.left = reconPreOrder(queue);
head.right = reconPreOrder(queue);
return head;
}
/**
* 层序遍历来序列化
* @param head
* @return
*/
public String serialByLevel(TreeNode head) {
if (head == null) {
return "#!";
}
String res = head.value + "!";
Queue<TreeNode> queue = new LinkedList<>();
queue.offer(head);
while (!queue.isEmpty()) {
head = queue.poll();
if (head.left != null) {
res += head.left.value + "!";
queue.offer(head.left);
} else {
res += "#!";
}
if (head.right != null) {
res += head.right.value + "!";
queue.offer(head.right);
} else {
res += "#!";
}
}
return res;
}
/**
* 反序列化--层遍历
* @param levelStr
* @return
*/
public TreeNode reconByLevelString(String levelStr) {
String[] values = levelStr.split("!");
int index = 0;
TreeNode head = generateNodeByString(values[index++]);
Queue<TreeNode> queue = new LinkedList<>();
if (head != null) {
queue.offer(head);
}
TreeNode treeNode = null;
while (!queue.isEmpty()) {
treeNode = queue.poll();
treeNode.left = generateNodeByString(values[index++]);
treeNode.right = generateNodeByString(values[index++]);
if (treeNode.left != null) {
queue.offer(treeNode.left);
}
if (treeNode.right != null) {
queue.offer(treeNode.right);
}
}
return head;
}
private TreeNode generateNodeByString(String val) {
if ("#".equals(val)) {
return null;
}
return new TreeNode(Integer.parseInt(val));
}
}
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/keke518/Algorithm.git
git@gitee.com:keke518/Algorithm.git
keke518
Algorithm
Algorithm
master

搜索帮助

A270a887 8829481 3d7a4017 8829481