当前位置: 首页 > news >正文

14 从中序和后序遍历构造二叉树

106. 从中序与后序遍历序列构造二叉树

中等

相关标签

premium lock icon相关企业

给定两个整数数组 inorderpostorder ,其中 inorder 是二叉树的中序遍历, postorder 是同一棵树的后序遍历,请你构造并返回这颗 二叉树

示例 1:

img

输入:inorder = [9,3,15,20,7], postorder = [9,15,7,20,3]
输出:[3,9,20,null,null,15,7]

示例 2:

输入:inorder = [-1], postorder = [-1]
输出:[-1]

提示:

  • 1 <= inorder.length <= 3000
  • postorder.length == inorder.length
  • -3000 <= inorder[i], postorder[i] <= 3000
  • inorderpostorder 都由 不同 的值组成
  • postorder 中每一个值都在 inorder
  • inorder 保证是树的中序遍历
  • postorder 保证是树的后序遍历

class Solution {
private:TreeNode* traversal (vector<int>& inorder, vector<int>& postorder) {if (postorder.size() == 0) return NULL;// 后序遍历数组最后一个元素,就是当前的中间节点int rootValue = postorder[postorder.size() - 1];TreeNode* root = new TreeNode(rootValue);// 叶子节点if (postorder.size() == 1) return root;// 找到中序遍历的切割点int delimiterIndex;for (delimiterIndex = 0; delimiterIndex < inorder.size(); delimiterIndex++) {if (inorder[delimiterIndex] == rootValue) break;}// 切割中序数组// 左闭右开区间:[0, delimiterIndex)vector<int> leftInorder(inorder.begin(), inorder.begin() + delimiterIndex);// [delimiterIndex + 1, end)vector<int> rightInorder(inorder.begin() + delimiterIndex + 1, inorder.end() );// postorder 舍弃末尾元素postorder.resize(postorder.size() - 1);// 切割后序数组// 依然左闭右开,注意这里使用了左中序数组大小作为切割点// [0, leftInorder.size)vector<int> leftPostorder(postorder.begin(), postorder.begin() + leftInorder.size());// [leftInorder.size(), end)vector<int> rightPostorder(postorder.begin() + leftInorder.size(), postorder.end());root->left = traversal(leftInorder, leftPostorder);root->right = traversal(rightInorder, rightPostorder);return root;}
public:TreeNode* buildTree(vector<int>& inorder, vector<int>& postorder) {if (inorder.size() == 0 || postorder.size() == 0) return NULL;return traversal(inorder, postorder);}
};
  • 这道题真的有点难

  • 步骤

    • 第一步:如果数组大小为零的话,说明是空节点了。
    • 第二步:如果不为空,那么取后序数组最后一个元素作为节点元素。
    • 第三步:找到后序数组最后一个元素在中序数组的位置,作为切割点
    • 第四步:切割中序数组,切成中序左数组和中序右数组 (顺序别搞反了,一定是先切中序数组)
    • 第五步:切割后序数组,切成后序左数组和后序右数组
    • 第六步:递归处理左区间和右区间
  • 每次都将原来的后序数组和中序数组切割,分别获得当前节点的左子树和右子树的后序数组和中序数组

http://www.jsqmd.com/news/810518/

相关文章:

  • FalcoClaw:为AI Agent与Linux工作负载构建自动化运行时安全响应引擎
  • 手把手教你为STM32F429的LTDC或大数组配置SDRAM:从硬件选型(W9825G6KH)到CubeMX参数详解
  • 基于比特币与IPFS构建去中心化身份锚点:原理、实现与应用
  • 北京手表回收哪家靠谱?2026 主流渠道实测对比,新手不踩坑 - 奢侈品回收测评
  • 多线程与并发编程
  • 在Windows上优雅处理PDF:Poppler工具包让你的文档工作更轻松
  • 嵌入式开发云端化:架构模式、实战评估与核心挑战解析
  • 风力叶片机器人喷涂轨迹规划仿真【附模型】
  • 利用Taotoken模型广场为不同项目选择合适大模型的策略
  • AI助手本地化办公:officecli-skills实现文档自动化生成
  • C/C++项目里stb_image库的‘multiple definition’报错,我用STB_IMAGE_STATIC宏解决了
  • 2026年金融AI投研炒股工具横评:五大主流平台深度对比推荐 - 品牌种草官
  • 【技术底稿 33】同机复用开发资源,搭建完整测试环境实战复盘一、核心背景
  • 基于Git工作流的OpenClaw状态备份工具clawsync设计与实践
  • 【仅限前500名】NotebookLM RAG私有化调优套件泄露版:含17个生产环境验证的prompt-sql混合检索模板+Latency-SLA监控看板
  • Python WebSocket 实时通信实战:构建实时Web应用
  • 告别答辩PPT焦虑:百考通AI一键生成,高效备战毕业答辩
  • AI时代的战神金刚——构建你的外部大脑与商业闭环@围巾哥萧尘
  • 【AI响应速度生死线】:Haiku在实时客服/编程助手/边缘设备的3大不可替代性验证
  • NotebookLM播客生成质量暴跌真相:训练数据污染率高达18.7%?我们逆向拆解了其RAG音频对齐层
  • LabVIEW主要设计特性与工程价值
  • STM32实战:BMP280气压模块IIC驱动与数据精准采集
  • 不靠感觉写代码:Matt Pocock 的 Skills 如何让 AI 写出你真正想要的代码
  • 半导体行业周期解析:从供需失衡到产业链博弈的生存指南
  • 终极音乐解锁指南:免费工具让你在任何设备播放加密音乐
  • 从底层逻辑了解AI
  • 基于SimpleX协议构建私有AI通信通道:OpenClaw插件部署指南
  • 氛围工程指南:如何量化与塑造技术团队的健康氛围
  • gptstudio:R语言数据分析的AI副驾驶,重塑RStudio工作流
  • 【ChatGPT Slogan生成黄金法则】:20年品牌技术专家亲授3步高转化文案炼金术