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; //下一个要处理的串
	}
      
      
     
     
    
    
   
   


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值