关于java:JZ061序列化二叉树

序列化二叉树

题目形容

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

  • 二叉树的序列化是指:把一棵二叉树依照某种遍历形式的后果以某种格局保留为字符串,从而使得内存中建设起来的二叉树能够长久保留。
  • 序列化能够基于先序、中序、后序、层序的二叉树遍历形式来进行批改,序列化的后果是一个字符串,序列化时通过
  • 某种符号示意空节点(#),以 ! 示意一个结点值的完结(value!)。
  • 二叉树的反序列化是指:依据某种遍历程序失去的序列化字符串后果str,重构二叉树。
  • 例如,咱们能够把一个只有根节点为1的二叉树序列化为”1,”,而后通过本人的函数来解析回这个二叉树

题目链接: 序列化二叉树

代码

/**
 * 题目:序列化二叉树
 * 题目形容
 * 请实现两个函数,别离用来序列化和反序列化二叉树
 * <p>
 * 二叉树的序列化是指:把一棵二叉树依照某种遍历形式的后果以某种格局保留为字符串,从而使得内存中建设起来的二叉树能够长久保留。
 * 序列化能够基于先序、中序、后序、层序的二叉树遍历形式来进行批改,序列化的后果是一个字符串,序列化时通过
 * 某种符号示意空节点(#),以 ! 示意一个结点值的完结(value!)。
 * <p>
 * 二叉树的反序列化是指:依据某种遍历程序失去的序列化字符串后果str,重构二叉树。
 * <p>
 * 例如,咱们能够把一个只有根节点为1的二叉树序列化为"1,",而后通过本人的函数来解析回这个二叉树
 * <p>
 * 题目链接:
 * https://www.nowcoder.com/practice/cf7e25aa97c04cc1a68c8f040e71fb84?tpId=13&&tqId=11214&rp=1&ru=/ta/coding-interviews&qru=/ta/coding-interviews/question-ranking
 */
public class Jz61 {

    private String deserializeStr;

    /**
     * 先序遍历
     *
     * @param root
     * @return
     */
    String serialize(TreeNode root) {
        if (root == null) {
            return "#";
        }
        return root.val + " " + serialize(root.left) + " " + serialize(root.right);
    }

    TreeNode deserialize(String str) {
        deserializeStr = str;
        return deserialize();
    }

    private TreeNode deserialize() {
        if (deserializeStr.length() == 0) {
            return null;
        }
        int index = deserializeStr.indexOf(" ");
        String node = index == -1 ? deserializeStr : deserializeStr.substring(0, index);
        deserializeStr = index == -1 ? "" : deserializeStr.substring(index + 1);
        if (node.equals("#")) {
            return null;
        }
        int val = Integer.valueOf(node);
        TreeNode t = new TreeNode(val);
        t.left = deserialize();
        t.right = deserialize();
        return t;
    }

    public static void main(String[] args) {
        TreeNode root = TreeNode.testCase1();

        Jz61 jz61 = new Jz61();
        String serialize = jz61.serialize(root);
        System.out.println(serialize);

        TreeNode rootCopy = jz61.deserialize(serialize);
        System.out.println(rootCopy);
    }
}

【每日寄语】 愿你明天温顺,优良,可恶,果决,一干二净。

评论

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

这个站点使用 Akismet 来减少垃圾评论。了解你的评论数据如何被处理