zoukankan      html  css  js  c++  java
  • 二叉树的序列化和反序列化

    就是内存里的一棵树如何变成字符串形式,又如何从字符串形式变成内存里的树

    如何判断一颗二叉树是不是另一棵二又树的子树?

     序列化、反序列化

    //以head为头的树,序列化成字符串返回
        public static String serialByPre(Node head) {
            if (head == null) {
                return "#_";
            }
            String res = head.value + "_";
            res += serialByPre(head.left);
            res += serialByPre(head.right);
            return res;
        }
    
        //反序列化至队列中
        public static Node reconByPreString(String preStr) {
            String[] values = preStr.split("_");
            Queue<String> queue = new LinkedList<String>();
            for (int i = 0; i != values.length; i++) {
                queue.offer(values[i]);
            }
            return reconPreOrder(queue);
        }
    
        //利用队列建立二叉树
        public static Node reconPreOrder(Queue<String> queue) {
            String value = queue.poll();
            if (value.equals("#")) {
                return null;
            }
            Node head = new Node(Integer.valueOf(value));
            head.left = reconPreOrder(queue);
            head.right = reconPreOrder(queue);
            return head;
        }

    示例:

    package Algorithms.tree;
    
    import java.util.LinkedList;
    import java.util.Queue;
    
    public class SerializeAndReconstructTree {
    
        public static class Node {
            public int value;
            public Node left;
            public Node right;
    
            public Node(int data) {
                this.value = data;
            }
        }
    
        //以head为头的树,序列化成字符串返回
        public static String serialByPre(Node head) {
            if (head == null) {
                return "#_";
            }
            String res = head.value + "_";
            res += serialByPre(head.left);
            res += serialByPre(head.right);
            return res;
        }
    
        //反序列化至队列中
        public static Node reconByPreString(String preStr) {
            String[] values = preStr.split("_");
            Queue<String> queue = new LinkedList<String>();
            for (int i = 0; i != values.length; i++) {
                queue.offer(values[i]);
            }
            return reconPreOrder(queue);
        }
    
        //利用队列建立二叉树
        public static Node reconPreOrder(Queue<String> queue) {
            String value = queue.poll();
            if (value.equals("#")) {
                return null;
            }
            Node head = new Node(Integer.valueOf(value));
            head.left = reconPreOrder(queue);
            head.right = reconPreOrder(queue);
            return head;
        }
    
        public static String serialByLevel(Node head) {
            if (head == null) {
                return "#_";
            }
            String res = head.value + "_";
            Queue<Node> queue = new LinkedList<Node>();
            queue.offer(head);
            while (!queue.isEmpty()) {
                head = queue.poll();
                if (head.left != null) {
                    res += head.left.value + "_";
                    queue.offer(head.left);
                } else {
                    res += "#_";
                }
                if (head.right != null) {
                    res += head.right.value + "_";
                    queue.offer(head.right);
                } else {
                    res += "#_";
                }
            }
            return res;
        }
    
        public static Node reconByLevelString(String levelStr) {
            String[] values = levelStr.split("_");
            int index = 0;
            Node head = generateNodeByString(values[index++]);
            Queue<Node> queue = new LinkedList<Node>();
            if (head != null) {
                queue.offer(head);
            }
            Node node = null;
            while (!queue.isEmpty()) {
                node = queue.poll();
                node.left = generateNodeByString(values[index++]);
                node.right = generateNodeByString(values[index++]);
                if (node.left != null) {
                    queue.offer(node.left);
                }
                if (node.right != null) {
                    queue.offer(node.right);
                }
            }
            return head;
        }
    
        public static Node generateNodeByString(String val) {
            if (val.equals("#")) {
                return null;
            }
            return new Node(Integer.valueOf(val));
        }
    
        // for test -- print tree
        public static void printTree(Node head) {
            System.out.println("Binary Tree:");
            printInOrder(head, 0, "H", 17);
            System.out.println();
        }
    
        public static void printInOrder(Node head, int height, String to, int len) {
            if (head == null) {
                return;
            }
            printInOrder(head.right, height + 1, "v", len);
            String val = to + head.value + to;
            int lenM = val.length();
            int lenL = (len - lenM) / 2;
            int lenR = len - lenM - lenL;
            val = getSpace(lenL) + val + getSpace(lenR);
            System.out.println(getSpace(height * len) + val);
            printInOrder(head.left, height + 1, "^", len);
        }
    
        public static String getSpace(int num) {
            String space = " ";
            StringBuffer buf = new StringBuffer("");
            for (int i = 0; i < num; i++) {
                buf.append(space);
            }
            return buf.toString();
        }
    
        public static void main(String[] args) {
            Node head = null;
            printTree(head);
    
            String pre = serialByPre(head);
            System.out.println("serialize tree by pre-order: " + pre);
            head = reconByPreString(pre);
            System.out.print("reconstruct tree by pre-order, ");
            printTree(head);
    
            String level = serialByLevel(head);
            System.out.println("serialize tree by level: " + level);
            head = reconByLevelString(level);
            System.out.print("reconstruct tree by level, ");
            printTree(head);
    
            System.out.println("====================================");
    
            head = new Node(1);
            printTree(head);
    
            pre = serialByPre(head);
            System.out.println("serialize tree by pre-order: " + pre);
            head = reconByPreString(pre);
            System.out.print("reconstruct tree by pre-order, ");
            printTree(head);
    
            level = serialByLevel(head);
            System.out.println("serialize tree by level: " + level);
            head = reconByLevelString(level);
            System.out.print("reconstruct tree by level, ");
            printTree(head);
    
            System.out.println("====================================");
    
            head = new Node(1);
            head.left = new Node(2);
            head.right = new Node(3);
            head.left.left = new Node(4);
            head.right.right = new Node(5);
            printTree(head);
    
            pre = serialByPre(head);
            System.out.println("serialize tree by pre-order: " + pre);
            head = reconByPreString(pre);
            System.out.print("reconstruct tree by pre-order, ");
            printTree(head);
    
            level = serialByLevel(head);
            System.out.println("serialize tree by level: " + level);
            head = reconByLevelString(level);
            System.out.print("reconstruct tree by level, ");
            printTree(head);
    
            System.out.println("====================================");
    
            head = new Node(100);
            head.left = new Node(21);
            head.left.left = new Node(37);
            head.right = new Node(-42);
            head.right.left = new Node(0);
            head.right.right = new Node(666);
            printTree(head);
    
            pre = serialByPre(head);
            System.out.println("serialize tree by pre-order: " + pre);
            head = reconByPreString(pre);
            System.out.print("reconstruct tree by pre-order, ");
            printTree(head);
    
            level = serialByLevel(head);
            System.out.println("serialize tree by level: " + level);
            head = reconByLevelString(level);
            System.out.print("reconstruct tree by level, ");
            printTree(head);
    
            System.out.println("====================================");
    
        }
    }
  • 相关阅读:
    P2216 [HAOI2007]理想的正方形(dp+单调队列优化)
    洛谷P1415 拆分数列(dp)
    2017 ACM-ICPC EC-Final ShangHai 东亚洲大陆-上海
    sql查询50题
    虚拟机安装
    Kick Start 2019 Round A Parcels
    Kick Start 2019 Round B Energy Stones
    【DP 好题】Kick Start 2019 Round C Catch Some
    【图论好题】ABC #142 Task F Pure
    【DP 好题】hihoCoder #1520 古老数字
  • 原文地址:https://www.cnblogs.com/zh-xiaoyuan/p/15134781.html
Copyright © 2011-2022 走看看