JZ-061-序列化二叉樹

雄獅虎豹發表於2022-02-15

序列化二叉樹

題目描述

請實現兩個函式,分別用來序列化和反序列化二叉樹。

  • 二叉樹的序列化是指:把一棵二叉樹按照某種遍歷方式的結果以某種格式儲存為字串,從而使得記憶體中建立起來的二叉樹可以持久儲存。
  • 序列化可以基於先序、中序、後序、層序的二叉樹遍歷方式來進行修改,序列化的結果是一個字串,序列化時通過
  • 某種符號表示空節點(#),以 ! 表示一個結點值的結束(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);
    }
}
【每日寄語】 願你今天溫柔,優秀,可愛,果斷,一塵不染。

相關文章