美文网首页
JZ-061-序列化二叉树

JZ-061-序列化二叉树

作者: 醉舞经阁半卷书 | 来源:发表于2022-02-15 17:42 被阅读0次

序列化二叉树

题目描述

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

  • 二叉树的序列化是指:把一棵二叉树按照某种遍历方式的结果以某种格式保存为字符串,从而使得内存中建立起来的二叉树可以持久保存。
  • 序列化可以基于先序、中序、后序、层序的二叉树遍历方式来进行修改,序列化的结果是一个字符串,序列化时通过
  • 某种符号表示空节点(#),以 ! 表示一个结点值的结束(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);
    }
}

【每日寄语】 愿你今天温柔,优秀,可爱,果断,一尘不染。

相关文章

  • JZ-061-序列化二叉树

    序列化二叉树 题目描述 请实现两个函数,分别用来序列化和反序列化二叉树。二叉树的序列化是指:把一棵二叉树按照某种遍...

  • 剑指offer刷题记录(C++版本)(之七)

    61.序列化二叉树??? 题目:请实现两个函数,分别用来序列化和反序列化二叉树 二叉树的序列化是指:把一棵二叉树按...

  • 二叉树的三种遍历方法

    二叉树的序列化 为了方便构造二叉树来验证我们的算法,这里先介绍下二叉树的序列化和反序列化。 序列化 先序遍历整颗二...

  • LeetCode:序列化二叉树

    面试题37. 序列化二叉树 请实现两个函数,分别用来序列化和反序列化二叉树。示例:你可以将以下二叉树: 序列化为 ...

  • 二叉树序列化和反序列化

    二叉树序列化和反序列化 前序 序列化和反序列化

  • 序列化二叉树

    题目描述 请实现两个函数,分别用来序列化和反序列化二叉树 思路 二叉树的序列化就是采用前序遍历二叉树输出节点,再碰...

  • 面试题37:序列化二叉树

    题目 实现两个函数,分别用来序列化和反序列化二叉树 解题思路 序列化根据前序遍历的顺序序列化二叉树,从根节点开始,...

  • 剑指Offer-61 二叉树序列化

    请实现两个函数,分别用来序列化和反序列化二叉树 利用广度遍历实现二叉树的序列化和非序列化。核心思想:广度遍历

  • 剑指Offer Java版 面试题37:序列化二叉树

    题目:请实现两个函数,分别用来序列化和反序列化二叉树。可以根据前序遍历的顺序来序列化二叉树。在遍历二叉树碰到nul...

  • 37:序列化二叉树

    题目37:序列化二叉树 请实现两个函数,分别用来序列化和反序列化二叉树。将树写入一个文件被称为“序列化”,读取文件...

网友评论

      本文标题:JZ-061-序列化二叉树

      本文链接:https://www.haomeiwen.com/subject/plsllrtx.html