297SerializeandDeserializeBinaryTree

题意:序列化是一个过程,将数据结构或者对象转化成位串,以便存进文件、缓冲区或者通过网络传输到对端再进行重构。

           设计算法实现二叉树的序列化和降序列化,对算法无性能要求,仅需保证二叉树能被序列化成字符串,同时字符串能被降序列为二叉树。

声明:不要使用类的成员、全局、静态的变量去存储状态,因为序列化和非序列化都是针对对象的,是无状态的。

思路:类似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; //下一个要处理的串
	}


你可能感兴趣的:(leetcode,算法)