内容简介:剑指offer-二叉树的重建(前序、中序遍历)
题目描述:输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。假设输入的前序遍历和中序遍历的结果都不含重复的数字。假如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序序列{4,7,2,1,5,3,8,6},则重建二叉树并返回。
问题分析:递归思想处理
前序遍历顺序为:节点->左子树->右子树
中序遍历顺序为:左子树->节点->右子树
在前序遍历数组中,拿到第一个节点数据,然后在中序遍历数组中找到该节点,然后将其数组分为两部分。然后根据两部分数组在重复以上动作分别重建其左子树与右子树。
代码实现:
TreeNode* reConstructBinaryTree(vector<int> pre,vector<int> vin) {
if(pre.empty()&&vin.empty())
return NULL;
TreeNode* root = new TreeNode(pre[0]);
int pos = 0;
for(pos;pos<vin.size();pos++)
{
if(pre[0] == vin[pos])
break;
}
vector<int>_preleft,_vinleft,_preright,_vinright;
for(int i = 0;i<pos;i++)
{
_preleft.push_back(pre[i+1]);
_vinleft.push_back(vin[i]);
}
for(int j = pos+1;j<vin.size();j++)
{
_preright.push_back(pre[j]);
_vinright.push_back(vin[j]);
}
root->left = reConstructBinaryTree(_preleft,_vinleft);
root->right = reConstructBinaryTree(_preright,_vinright);
return root;
}
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
深度探索C++对象模型(影印版)
Stanley B. Lippman / 中国电力出版社 / 2003-8-1 / 42.00
本书重点介绍了C++面向对象程序设计的底层机制,包括结构式语意、暂时性对象的生成、封装、继承和虚拟——虚拟函数和虚拟继承。书中向你表明:理解底层实现模型,可以极大地提高你的编码效率。Lippman澄清了那些关于C++系统开销与复杂性的各种错误信息和猜测,指出了其中某些成本和利益交换确实存在。他在书中详述了各种实现模型,指出了它们的发展方向以及促使其发展的根本原因。本书涵盖了C++对象模型的语意暗示......一起来看看 《深度探索C++对象模型(影印版)》 这本书的介绍吧!
SHA 加密
SHA 加密工具
Markdown 在线编辑器
Markdown 在线编辑器