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

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

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

  • 标签:#树 #数组 #哈希表 #分治 #二叉树
    • Ⅰ. 题目
    • Ⅱ. 示例
  • 0. 个人方法

标签:#树 #数组 #哈希表 #分治 #二叉树

Ⅰ. 题目

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

Ⅱ. 示例

· 示例 1:

输入: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]

0. 个人方法

这题和上一题(LeetCode105)很像,这里不做过多赘述,有需要的朋友们可以直接点击超链接去看看。

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     TreeNode *left;*     TreeNode *right;*     TreeNode() : val(0), left(nullptr), right(nullptr) {}*     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}*     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}* };*/
class Solution {
public:TreeNode* buildTree(vector<int>& inorder, vector<int>& postorder) {return buildTreeRoot(inorder, 0, inorder.size()-1, postorder, 0, postorder.size()-1);}TreeNode* buildTreeRoot(const vector<int>& inorder,   int inStart,   int inEnd, const vector<int>& postorder, int postStart, int postEnd){if (inStart > inEnd || postStart > postEnd){return nullptr;}// 根结点TreeNode* root = new TreeNode(postorder[postEnd]);// 找中序遍历中的根结点int mid = 0;for (int i=inStart; i<=inEnd; i++){if (inorder[i] == postorder[postEnd]){mid = i;break;}}int leftsize = mid - inStart;// int rightsize = inEnd - mid;root->left = buildTreeRoot(inorder, inStart, mid-1, postorder, postStart, postStart+leftsize-1);root->right = buildTreeRoot(inorder, mid+1, inEnd, postorder, postStart+leftsize, postEnd-1);return root;}
};

相关文章:

  • LeetCode第190题_颠倒二进制位
  • BUUCTF——杂项渗透之神秘的文件
  • 信创生态核心技术栈:国产芯片架构适配详解
  • OpenCV计算机视觉实战(3)——计算机图像处理基础
  • VUE+ElementUI 使用el-input类型type=“number” 时,取消右边的上下箭头
  • Pdf转Word案例(java)
  • Carlink 技术:搭建汽车与手机的智能桥梁
  • react+ts中函数组件父子通信方式
  • React Fiber
  • Canal mysql to mysql 增加 online 库同步配置指南
  • 【基础】Python包管理工具uv使用全教程
  • 13前端项目----购物车修改
  • MySQL初阶:基础增删改查(CRUD)
  • vue3使用轮播图组件swiper
  • 2.Redis高阶实战
  • On the Biology of a Large Language Model——论文学习笔记——拒答和越狱
  • 点分治解析
  • Python __new__ 一个特殊的静态方法
  • 使用Windows+Linux实现mysql的主从复制
  • LangChain入门(六)Agent
  • 青年与人工智能共未来,上海创新创业青年50人论坛徐汇分论坛举办
  • 新疆维吾尔自治区乌鲁木齐市米东区政协原副主席朱文智被查
  • 昆明阳宗海风景名胜区19口井违规抽取地热水,整改后用自来水代替温泉
  • “救护车”转运病人半路加价,从宝鸡到西安往返都要多收钱
  • 绿城约13.93亿元竞得西安浐灞国际港港务片区地块,区内土地楼面单价首次冲破万元
  • 经济日报:降准降息,提前还房贷划算吗?