zoukankan      html  css  js  c++  java
  • 0449. Serialize and Deserialize BST (M)

    Serialize and Deserialize BST (M)

    题目

    Serialization is converting a data structure or object into a sequence of bits so that it can be stored in a file or memory buffer, or transmitted across a network connection link to be reconstructed later in the same or another computer environment.

    Design an algorithm to serialize and deserialize a binary search tree. There is no restriction on how your serialization/deserialization algorithm should work. You need to ensure that a binary search tree can be serialized to a string, and this string can be deserialized to the original tree structure.

    The encoded string should be as compact as possible.

    Example 1:

    Input: root = [2,1,3]
    Output: [2,1,3]
    

    Example 2:

    Input: root = []
    Output: []
    

    Constraints:

    • The number of nodes in the tree is in the range [0, 104].
    • 0 <= Node.val <= 104
    • The input tree is guaranteed to be a binary search tree.

    题意

    实现BST的序列化和反序列化。

    思路

    可以用DFS实现,先序遍历将(根2,左1,右3)的BST序列化为"2 1 # # 3 # #"(#代表null)的形式,反序列化时以相同的顺序原样恢复。


    代码实现

    Java

    public class Codec {
    
        // Encodes a tree to a single string.
        public String serialize(TreeNode root) {
            StringBuilder sb = new StringBuilder();
            serialize(root, sb);
            return sb.toString().trim();
        }
    
        // Decodes your encoded data to tree.
        public TreeNode deserialize(String data) {
            String[] ss = data.split(" ");
            Queue<String> q = new LinkedList<>();
            for (String s : ss) {
                q.offer(s);
            }
            return deserialize(q);
        }
    
        private void serialize(TreeNode root, StringBuilder sb) {
            if (root == null) {
                sb.append("# ");
                return;
            }
    
            sb.append(root.val + " ");
            serialize(root.left, sb);
            serialize(root.right, sb);
        }
    
        private TreeNode deserialize(Queue<String> q) {
            if (q.isEmpty()) {
                return null;
            }
    
            if (q.peek().equals("#")) {
                q.poll();
                return null;
            }
    
            TreeNode root = new TreeNode(Integer.parseInt(q.poll()));
            root.left = deserialize(q);
            root.right = deserialize(q);
            return root;
        }
    }
    
  • 相关阅读:
    【linux 文件管理】7-文件重定向
    by David Bombal CCNA with kali linux
    【linux 文件管理】6-软链接和硬链接
    13.mysql索引的使用
    11.mysql SQL优化之SQL问题定位
    mysql服务常用命令
    10.mysql存储引擎
    9. Mysql的体系结构概览
    8.mysql触发器
    项目上线部署
  • 原文地址:https://www.cnblogs.com/mapoos/p/13788120.html
Copyright © 2011-2022 走看看