码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 已知前序中序遍历,求二叉树的高度


     

    此题所涉及的建树详细请见我上一篇博文,二叉树的构造,这种构造方法简单容易理解 

    此处求树高采用的是递归求解,对每一层最长树加上当前节点的高度 

    1. #include
    2. #include
    3. #include
    4. using namespace std;
    5. struct TreeNode {
    6. char val;
    7. TreeNode* left;
    8. TreeNode* right;
    9. TreeNode(char val) : val(val), left(nullptr), right(nullptr) {}
    10. };
    11. // 根据先序遍历和中序遍历序列构造二叉树
    12. TreeNode* buildTree(string& preorder, string& inorder,
    13. int preStart, int inStart, int inEnd,
    14. unordered_map<char, int>& indexMap) {
    15. if (preStart > preorder.size() - 1 || inStart > inEnd) {
    16. return nullptr;
    17. }
    18. char rootValue = preorder[preStart];
    19. TreeNode* root = new TreeNode(rootValue);
    20. int rootIndex = indexMap[rootValue];
    21. root->left = buildTree(preorder, inorder, preStart + 1, inStart, rootIndex - 1, indexMap);
    22. root->right = buildTree(preorder, inorder, preStart + rootIndex - inStart + 1, rootIndex + 1, inEnd, indexMap);
    23. return root;
    24. }
    25. // 计算二叉树的高度
    26. int getHeight(TreeNode* root) {
    27. if (root == nullptr) {
    28. return 0;
    29. }
    30. int leftHeight = getHeight(root->left);
    31. int rightHeight = getHeight(root->right);
    32. return max(leftHeight, rightHeight) + 1;
    33. }
    34. int main() {
    35. int n;
    36. while (cin >> n) {
    37. string preorder, inorder;
    38. cin >> preorder >> inorder;
    39. unordered_map<char, int> indexMap;
    40. for (int i = 0; i < n; ++i) {
    41. indexMap[inorder[i]] = i;
    42. }
    43. TreeNode* root = buildTree(preorder, inorder, 0, 0, n - 1, indexMap);
    44. int height = getHeight(root);
    45. cout << height << endl;
    46. }
    47. return 0;
    48. }

     

  • 相关阅读:
    Envoy代理GRPC服务支持通过restful进行访问
    VS 常用的快捷键指令
    Radis缓存异常以及处理方案(雪崩击穿穿透预热降级)
    Github星标90K?京东架构师一篇讲明白百亿级并发系统架构设计
    Linux环境修改服务器时间和网络时间保持一致
    xlight ftp服务器软件设置
    IVIEW Table/Div 自适应高度
    文本的设置
    MySQL、redis、MongoDB、elasticsearch的对比
    【编程不良人】SpringSecurity实战学习笔记04---RememberMe
  • 原文地址:https://blog.csdn.net/m0_62512076/article/details/133135027
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号