当前位置:网站首页>从中序与后序遍历序列构造二叉树
从中序与后序遍历序列构造二叉树
2022-08-05 18:14:00 【泊云V】
从中序与后序遍历序列构造二叉树
来自学习总结
1.问题描述:
根据一棵树的
中序遍历与后序遍历构造二叉树(假设树中没有重复的元素)中序遍历
inorder= [9,3,15,20,7] 后序遍历postorder= [9,15,7,20,3] 返回如下的二叉树:

2.思路
以后序数组的最后一个元素为
切割点,先切中序数组,根据中序数组,反过来切后序数组,一层一层切下去,每次后续数组最后一个元素就是节点元素
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Kppt0Y0Q-1659594016685)(../../../../002%E6%96%87%E6%A1%A3/Typroa/images/image-20220804113143791.png)]](/img/46/2ee4a9ef1005f148ea95f6cb3ae84f.png)
一层一层切割的步骤:(递归)
- 如果数组大小为
0,说明是空节点- 若不为空,name去后序数组最后一个元素作为节点元素
- 找到后序数组最后一个元素在中序数组的位置,作为切割点
- 切割中序数组,切成中序左数组和中序右数组
- 切割后续数组,切成后续数组和后序数组
- 递归处理左区间和右区间
4.代码实现
public TreeNode* traversal(vector<int>& inorder,vector<int>& postorder){
//1.
if(postorder.size()==0) return null;
//2.后续遍历的最后一个元素,就是当前的节点
int rootVal=postorder[postorder.size()-1];
TreeNode* root=new TreeNode(rootVal);
//叶子结点
if(postorder.size()==1) return root;
//3.切割点
int delimiterIndex;
for(delimiterIndex=0;delimiterIndex<inorder.size();delimiterIndex++){
if(inorder[delimiterIndex]==rootVal) break;
}
//4切割中序数组
//左闭右开区间[0,delimiterIndex)
vector<int> leftInorder(inorder.begin(),inorder.begin()+delimiterIndex);
//[delimiterIndex+1,end)
vector<int> rightInorder(inorder.begin()+delimiterIndex+1,index.end());
//舍弃末尾元素
postorder.resize(postorder.size()-1);
//5切割后序数组
//左闭右开,注意这里使用了左中序数组大小作为切割点[0,leftorder.size)
vector<int> leftPostOrder(postorder.begin(),postorder.begin()+leftInorder.size());
//[leftInorder.size(),end)
vector<int> rightPostorder(postorder.begin()+leftInorder.size(),postorder.end());
//6.
root->left=traversal();
root->right=traversal();
return root;
}
边栏推荐
猜你喜欢
随机推荐
Kubernetes 服务发现
npm WARN config global `--global`, `--local` are deprecated. Use `--location=global` instead.
SVG+JS圆形菜单插件
How WPF+SkiaSharp implements self-drawn shooting game
YOLOV5学习笔记(五)——使用代码detect train讲解
Can the code signing certificate solve the software being alerted by antivirus software?
金仓数据库 KingbaseGIS 使用手册(5. 使用几何对象:构建应用)
BFD实验演示(Huawei路由器设备配置)
第十五天实验
FPGA解析B码----连载5
Docker安装Mysql5.7
倪光南:openEuler已达国际同类社区水准
点击 Fiori Launchpad tile 后报错的处理方法
本周投融报:NFT工具受资本青睐
记一次Max模型导入到GIS平台歪了,尺寸不对过程分析
包载信使mRNA的多西环素纳米脂质体|雷公藤红素纳米脂质体RNA核糖核酸(实验原理)
浏览器窗口尺寸相关的 API 整理图
1.9 亿美元被“掏空”!黑客牵头,路人“趁火打劫”,一切仅因一个低级致命漏洞...
Golang 汇编asm语言基础学习
eKuiper Newsletter 2022-07|v1.6.0:Flow 编排 + 更好用的 SQL,轻松表达业务逻辑









