当前位置:网站首页>从中序与后序遍历序列构造二叉树
从中序与后序遍历序列构造二叉树
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;
}
边栏推荐
猜你喜欢
随机推荐
OpenCV创建矩阵以及转为Eigen矩阵
PNAS:alpha频率经颅电刺激调控大脑默认网络
浏览器窗口尺寸相关的 API 整理图
插槽的三大类
如何编写有效的FAQ常见问题页面
调用colmap作为my项目第三方库,debug进入colmap代码调试--CMakeLists配置
go基础之web应用
Docker安装Mysql5.7
Kubernetes 服务发现
国标视频云服务EasyGBS如何正确调阅实时录像接口?
文盘Rust -- 配置文件解析
做个男人,做个成熟的男人
点击 Fiori Launchpad tile 后报错的处理方法
JWT漏洞详解
一起探秘,不可不知双向链表底层原理
手撕神经网络 numpy
译文推荐|Apache Pulsar 隔离系列(四):单集群隔离策略
FPGA解析B码----连载5
NFT 的潜力:扩展的艺术品鉴定证书
js文字开场百叶窗js特效









