[LeetCode 297] Serialize and Deserialize Binary Tree

原创 2015年11月18日 16:28:34



Serialization is the process of 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 tree. There is no restriction on how your serialization/deserialization algorithm should work. You just need to ensure that a binary tree can be serialized to a string and this string can be deserialized to the original tree structure.

For example, you may serialize the following tree

    1
   / \
  2   3
     / \
    4   5
as "[1,2,3,null,null,4,5]", just the same as how LeetCode OJ serializes a binary tree. You do not necessarily need to follow this format, so please be creative and come up with different approaches yourself.

Note: Do not use class member/global/static variables to store states. Your serialize and deserialize algorithms should be stateless.


solution:

1. preorder traversal, use another helper class(StringToken) to split string, and record current position

2. level order traversal


public class Codec {

        
 // Encodes a tree to a single string.
    public String serialize(TreeNode root) {
        StringBuilder sb = new StringBuilder();
        helptoserialize(root, sb);
        return sb.toString();
    }

    public void helptoserialize(TreeNode root, StringBuilder sb) {
        if(root == null) {
            sb.append("# ");
        } else {
            sb.append(root.val);
            sb.append(" ");
            helptoserialize(root.left, sb);
            helptoserialize(root.right, sb);
        }
    }

    // Decodes your encoded data to tree.
    public TreeNode deserialize(String data) {
        TreeNode root = helptodeserialize(new StringToken(data, " "));
        return root;
    }
    
    public TreeNode helptodeserialize(StringToken token) {
        if(!token.hasMoreElement()) return null;
        String t1 = token.nextElement();
        if(t1.equals("#")) return null;
        TreeNode root = new TreeNode(Integer.valueOf(t1));
        root.left = helptodeserialize(token);
        root.right = helptodeserialize(token);
        return root;
    }

    class StringToken {
        public int len = 0;
        ArrayList<String> dataStrings = new ArrayList<>();
        public StringToken (String data, String spliter) {
            String[] datas = data.split(spliter);
            for(int i=0;i<datas.length;i++) {
                dataStrings.add(datas[i]);
            }
        }
        public boolean hasMoreElement() {
            return len<dataStrings.size();
        }
        public String nextElement() {
            return dataStrings.get(len++);
        }
    }
}


Leetcode-Symmetric Tree——判断二叉树是否对称

题目 Symmetric Tree  Total Accepted: 12814 Total Submissions: 40358My Submissions Given a bina...
  • disappearedgod
  • disappearedgod
  • 2014年04月20日 01:00
  • 2060

Java序列化(Serialize)和反序列化(Deserialize)

对象的序列化一、目的: 将对象转换成与平台无关的二进制流,从而可以保存到磁盘或者进行网络传输,其它程序获 得这个二进制流后可以将其还原成对象。 序列化机制可以使对象可以脱离程序的...
  • qq_25859403
  • qq_25859403
  • 2016年07月04日 00:08
  • 3825

LeetCode_将LeetCode中的字符串用例转换成二叉树

最近刷LeetCode题目时总会出现错误时,手动生成用例的情况,于是自己写了一个将...
  • loveRooney
  • loveRooney
  • 2014年06月22日 15:02
  • 1600

二叉搜索树(Binary Search Tree )的定义及分析

定义:     二叉搜索树或者是一棵空树,或者是具有下列性质的二叉树: 每个结点都有一个作为搜索依据的关键码(key),所有结点的关键码互不相同。 左子树(如果非空)上所...
  • jsh13417
  • jsh13417
  • 2013年01月22日 21:59
  • 3358

二叉搜索树(Binary Search Tree)的插入与删除

二叉搜索树的插入关键是要找到元素应该插入的位置,可以采用与Find类似的方法。 二叉搜索树的删除则要考虑三种情况:   1.要删除的是叶节点:直接删除,并再修改其父节点指针置为NULL ...
  • song_hui_xiang
  • song_hui_xiang
  • 2015年08月16日 13:10
  • 988

数据结构(Java语言)——BinarySearchTree简单实现

二叉树的一个重要应用是它们在查找中的使用。使二叉树成为二叉查找树的性质是,对于树中的每个节点X,它的左子树中所有项的值都大于X中的项。注意,这意味着该树所有的元素都可以用某种一致的方式排序。 现在给出...
  • zhang_zp2014
  • zhang_zp2014
  • 2015年08月14日 21:55
  • 937

Leetcode Symmetric Tree 递归和非递归解法

和same tree题目差不多一样的解法。 1 recursively 递归法: 2 iteratively 非递归: 使用先序遍历,原来树的先序遍历的非递归写法也不简单。...
  • kenden23
  • kenden23
  • 2014年02月16日 01:11
  • 14318

LeetCode之Tree题目汇总

Balanced Binary TreeGiven a binary tree, determine if it is height-balanced.For this problem, a heig...
  • Yano_nankai
  • Yano_nankai
  • 2015年12月29日 20:43
  • 696

算法导论C语言实现: 二叉搜索树(binary tree)

1. 源代码 ia_binarytree.h #ifndef __IA_BINARY_TREE_H__ #define __IA_BINARY_TREE_H__ #include typede...
  • v2nero
  • v2nero
  • 2014年01月05日 22:38
  • 1192

[Go语言]binary tree算法的华山论剑

在benchmarkgame(世界上最火的性能对比网站)上,Go语言一直有一个槽点,就是极其慢的binary tree性能,执行用时40秒 (我的机器上,16秒),与此对比,Java版本是6秒,那么问...
  • abv123456789
  • abv123456789
  • 2016年12月31日 16:32
  • 2765
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:[LeetCode 297] Serialize and Deserialize Binary Tree
举报原因:
原因补充:

(最多只允许输入30个字)