题意:序列化是一个过程,将数据结构或者对象转化成位串,以便存进文件、缓冲区或者通过网络传输到对端再进行重构。
设计算法实现二叉树的序列化和降序列化,对算法无性能要求,仅需保证二叉树能被序列化成字符串,同时字符串能被降序列为二叉树。
声明:不要使用类的成员、全局、静态的变量去存储状态,因为序列化和非序列化都是针对对象的,是无状态的。
思路:类似BFS,数据结构队列,处理父节点时就需要处理孩子节点,否则无法建立父子之间的链接。
// Encodes a tree to a single string.
public String serialize(TreeNode root) { //BFS
if(root == null)
return "";
StringBuilder strBuilder = new StringBuilder();
Deque
tree = new LinkedList<>();
tree.add(root);
strBuilder.append(root.val + " ");//分隔符:“ ”
TreeNode node;
while(!tree.isEmpty()){
node = tree.removeFirst();
solChild(node, strBuilder, tree); //孩子成对出现
}
return strBuilder.toString();
}
private void solChild(TreeNode node, StringBuilder strBuilder, Deque
tree) {
if(node.left != null){
strBuilder.append(node.left.val + " ");
tree.add(node.left);
}else {
strBuilder.append("* ");
}
if(node.right != null){
strBuilder.append(node.right.val + " ");
tree.add(node.right);
}else {
strBuilder.append("* ");
}
}
// Decodes your encoded data to tree.
public TreeNode deserialize(String data) {
if(data.equals(""))
return null;
String[] strTokens = data.split(" ");
Deque
tree = new LinkedList<>();
TreeNode root = new TreeNode(Integer.parseInt(strTokens[0]));
tree.add(root);
int index = 1, ret;
while(!tree.isEmpty()){
TreeNode node = tree.removeFirst();
ret = revChild(node, strTokens, index, tree);
index = ret;
}
return root;
}
//node:父节点 ---> strTokens[i]
private int revChild(TreeNode node, String[] strTokens, int index, Deque
tree) {
if(strTokens[index].equals("*")){//null 左孩子
node.left = null;
} else{
node.left = new TreeNode(Integer.parseInt(strTokens[index]));
tree.add(node.left); //add reference
}
index++;
if(strTokens[index].equals("*")){//null 右孩子
node.right = null;
} else{
node.right = new TreeNode(Integer.parseInt(strTokens[index]));
tree.add(node.right);
}
index++;
return index; //下一个要处理的串
}