请实现两个函数,分别用来序列化和反序列化二叉树。
示例:
你可以将以下二叉树:
1 / \ 2 3 / \ 4 5
序列化为 “[1,2,3,null,null,4,5]”
思路:
序列化:这里用到了BFS,进行层序遍历。
反序列化:这里也是使用的层序遍历BFS,通过一个index指针来表明当前所处的位置。当str[i]!=null的时候,表示此处有值,需要创建一个新的节点,并且将该节点入队
复杂度:
时间:O(N)
序列化,反序列化都是需要遍历这个数,或是数组,时间复杂度为N
空间:O(N)
序列化需要借助一个Queue队列,当为链表的时候队列最大为N
反序列化也需要一个队列,需要的空间最大为N
/**
* Definition for a binary tree node.
* public class TreeNode {
* int val;
* TreeNode left;
* TreeNode right;
* TreeNode(int x) { val = x; }
* }
*/
class Codec {
// Encodes a tree to a single string.
public String serialize(TreeNode root) {
//BFS思想
if(root==null)
return "[]";
StringBuilder res=new StringBuilder("[");
Queue<TreeNode> queue=new LinkedList<>();
queue.add(root);
while(!queue.isEmpty()){
TreeNode node=queue.poll();
if(node!=null){
res.append(node.val+",");
queue.add(node.left);
queue.add(node.right);
}else{
res.append("null,");
}
}
//最后会多一个,
res.deleteCharAt(res.length()-1);
res.append("]");
return res.toString();
}
// Decodes your encoded data to tree.
public TreeNode deserialize(String data) {
if(data.equals("[]"))
return null;
String[] str=data.substring(1,data.length()-1).split(",");
TreeNode root=new TreeNode(Integer.parseInt(str[0]));
Queue<TreeNode> queue=new LinkedList<>();
queue.add(root);
int i=1;
while(!queue.isEmpty()){
TreeNode n=queue.poll();
if(!str[i].equals("null")){
TreeNode node=new TreeNode(Integer.parseInt(str[i]));
n.left=node;
//入队
queue.add(node);
}
i++;
if(!str[i].equals("null")){
TreeNode node=new TreeNode(Integer.parseInt(str[i]));
n.right=node;
queue.add(node);
}
i++;
}
return root;
}
}
// Your Codec object will be instantiated and called as such:
// Codec codec = new Codec();
// codec.deserialize(codec.serialize(root));