请实现两个函数,分别用来序列化和反序列化二叉树

序列化二叉树

http://www.nowcoder.com/questionTerminal/cf7e25aa97c04cc1a68c8f040e71fb84

解题思路

序列化二叉树

递归遍历二叉树的节点,空节点使用#代替,节点之间使用逗号隔开,返回字符串

反序列化二叉树

设置序号index,将字符串根据逗号分割为数组,根据index的值来设置树节点的val,如果节点的值为#,则返回空的树节点。

public class SerializeTree {

    int index = -1;
    /**
     * 分别遍历左节点和右节点,空使用#代替,节点之间,隔开
     *
     * @param root
     * @return
     */
    public String Serialize(TreeNode root) {
        if (root == null) {
            return "#";
        } else {
            return root.val + "," + Serialize(root.left) + "," + Serialize(root.right);
        }
    }
    /**
     * 使用index来设置树节点的val值,递归遍历左节点和右节点,如果值是#则表示是空节点,直接返回
     *
     * @param str
     * @return
     */
    TreeNode Deserialize(String str) {
        String[] s = str.split(",");//将序列化之后的序列用,分隔符转化为数组
        index++;//索引每次加一
        int len = s.length;
        if (index > len) {
            return null;
        }
        TreeNode treeNode = null;
        if (!s[index].equals("#")) {//不是叶子节点 继续走 是叶子节点出递归
            treeNode = new TreeNode(Integer.parseInt(s[index]));
            treeNode.left = Deserialize(str);
            treeNode.right = Deserialize(str);
        }
        return treeNode;
    }

    public static void main(String[] args) {
        TreeNode treeNode1 = new TreeNode(1);
        TreeNode treeNode2 = new TreeNode(2);
        TreeNode treeNode3 = new TreeNode(3);
        TreeNode treeNode4 = new TreeNode(4);
        TreeNode treeNode5 = new TreeNode(5);
        TreeNode treeNode6 = new TreeNode(6);

        treeNode1.left = treeNode2;
        treeNode1.right = treeNode3;

        treeNode2.left = treeNode4;
        treeNode3.left = treeNode5;
        treeNode3.right = treeNode6;

        SerializeTree serializeTree = new SerializeTree();

        String str = serializeTree.Serialize(treeNode1);
        TreeNode treeNode = serializeTree.Deserialize(str);
    }
}
全部评论
27 行应该是>= 吧。等于的时候数组也越界了, index 从0 开始标记的
6 回复 分享
发布于 2020-04-17 11:25
if (index > len) { return null; } 这段是不是不需要啊,等于# 已经给返回了null了
点赞 回复 分享
发布于 2023-01-11 23:51 北京
每次递归都split一次整个序列化字符串,效率也太低了吧
点赞 回复 分享
发布于 2021-08-02 00:42
很清晰,12行应该再加一个','
点赞 回复 分享
发布于 2021-04-10 21:23
感觉不需要判断index会不会越界,只需要递增就可以了,递归机制保证了不会越界
点赞 回复 分享
发布于 2021-03-08 18:25
14行 为什么Serilize(root.right)后面不加","啊?
点赞 回复 分享
发布于 2020-05-24 09:54
老哥没有用到‘!’
点赞 回复 分享
发布于 2020-04-17 10:45

相关推荐

05-19 15:21
已编辑
华南农业大学 Java
白火同学:你才沟通了200,说实话,北上广深杭这里面你连一座城市的互联网公司都没投满呢,更别说还有各种准一线二线城市了。等你沟通突破了三位数,还没结果再考虑转行的事吧。
点赞 评论 收藏
分享
评论
49
1
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务