码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【剑指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.从前序与中序遍历序列构造二叉树

  • 相关阅读:
    [MySQL]DQL,Data Query Language(数据查询语言)
    六、鼎捷T100采购应付之应付暂估管理篇
    LangChain:打造自己的LLM应用 | 京东云技术团队
    京东商品质量分检测,如何一键检测全店?
    Pandas初级认识
    ntp时间同步和ssh免密登录
    人工智能、深度学习、机器学习常见面试题71~82
    golang rabbitmq客户端连接及重连
    SQL DELETE 语句:删除表中记录的语法和示例,以及 SQL SELECT TOP、LIMIT、FETCH FIRST 或 ROWNUM 子句的使用
    python打包原理
  • 原文地址:https://blog.csdn.net/qq_57438473/article/details/133418923
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号