• 【剑指Offer】7.重建二叉树


    题目

    给定节点数为 n 的二叉树的前序遍历和中序遍历结果,请重建出该二叉树并返回它的头结点。

    例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2,1,5,3,8,6},则重建出如下图所示。

    提示:

    1.vin.length == pre.length

    2.pre 和 vin 均无重复元素

    3.vin出现的元素均出现在 pre里

    4.只需要返回根结点,系统会自动输出整颗树做答案对比

    数据范围:0n≤2000,节点的值 −10000≤val≤10000

    要求:空间复杂度 O(n),时间复杂度 O(n)

    示例1

    输入:[1,2,4,7,3,5,6,8],[4,7,2,1,5,3,8,6]

    返回值:{1,2,3,4,#,5,6,#,7,#,#,8}

    说明:返回根节点,系统会输出整颗二叉树对比结果,重建结果如题面图示

    示例2

    输入:[1],[1]

    返回值:{1}

    示例3

    输入:[1,2,3,4,5,6,7],[3,2,4,1,6,5,7]

    返回值:{1,2,5,3,4,6,7}

    解答

    源代码

    1. /*
    2. * public class TreeNode {
    3. * int val = 0;
    4. * TreeNode left = null;
    5. * TreeNode right = null;
    6. * public TreeNode(int val) {
    7. * this.val = val;
    8. * }
    9. * }
    10. */
    11. public class Solution {
    12. /**
    13. * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
    14. *
    15. *
    16. * @param preOrder int整型一维数组
    17. * @param vinOrder int整型一维数组
    18. * @return TreeNode类
    19. */
    20. Map indexMap = new HashMap<>();
    21. public TreeNode reConstructBinaryTree (int[] preOrder, int[] vinOrder) {
    22. // write code here
    23. for (int i = 0; i < vinOrder.length; i++) {
    24. indexMap.put(vinOrder[i], i);
    25. }
    26. return myBuildTree(preOrder, vinOrder, 0, vinOrder.length - 1, 0, vinOrder.length - 1);
    27. }
    28. public TreeNode myBuildTree(int[] preOrder, int[] vinOrder, int preLeft, int preRight, int vinLeft, int vinRight) {
    29. if (preLeft > preRight) {
    30. return null;
    31. }
    32. TreeNode root = new TreeNode(preOrder[preLeft]);
    33. // 中序遍历中根节点的索引
    34. int vinRootIndex = indexMap.get(preOrder[preLeft]);
    35. // 左子树大小
    36. int leftSize = vinRootIndex - vinLeft;
    37. // 右子树大小
    38. int rightSize = vinRight - vinRootIndex;
    39. root.left = myBuildTree(preOrder, vinOrder, preLeft + 1, preLeft + leftSize, vinLeft, vinRootIndex - 1);
    40. root.right = myBuildTree(preOrder, vinOrder, preLeft + leftSize + 1, preRight, vinRootIndex + 1, vinRight);
    41. return root;
    42. }
    43. }

    总结

    这道题和LeetCode105一样。

    详细题解见【LeetCode】105.从前序与中序遍历序列构造二叉树

  • 相关阅读:
    二、MyBatis-Plus 主键策略
    WPF中非递归(无后台代码)动态实现TreeView
    简单c++计算器
    搭建一个springboot项目的基本流程
    React中实现一键复制——五种办法
    jQuery 常用函数解析
    前后端交互案例,图书管理系统
    【MISRA C 2012】Rule 4.2 不应该使用三连符
    python列表list的index方法的用法和实例
    Spring AOP使用与原理
  • 原文地址:https://blog.csdn.net/qq_57438473/article/details/133418923