七:重建二叉树(根据先序遍历(或者后序遍历)和中序遍历重建二叉树)
来源:互联网 发布:网络电视无信号 编辑:程序博客网 时间:2024/06/04 18:28
对于一颗二叉树,可以根据先序遍历(或者后序遍历)和中序遍历(树中不含重复的数字)重新还原出二叉树。
解析:
1. 先序遍历序列的第一个元素必定是根节点,可以由此获取二叉树的根节点。
2. 根据根节点,在中序遍历序列中查找该节点,由中序遍历的性质可知,中序遍历中该根节点左边的序列必定在根节点的左子树中,而根节点右边的序列必定在右子树中。由此可以知道先序遍历中左子树以及右子树的起止位置。
3. 找到了左右子树前序遍历和中序遍历再用同样的方法分别构建左右子树,典型的递归思想。
代码如下:
BinaryTreeNode* ConstructCore
(
int* startPreorder, int* endPreorder,
int* startInorder, int* endInorder
)
{
// 前序遍历序列的第一个数字是根结点的值
int rootValue = startPreorder[0];
BinaryTreeNode* root = new BinaryTreeNode();
root->m_nValue = rootValue;
root->m_pLeft = root->m_pRight = NULL;
if(startPreorder == endPreorder)
{
if(startInorder == endInorder && *startPreorder ==*startInorder)
return root;
else
throw std::exception("Invalid input.");
}
// 在中序遍历中找到根结点的值
int* rootInorder = startInorder;
while(rootInorder <= endInorder && *rootInorder != rootValue)
++ rootInorder;
//判断是否找到根节点
if(rootInorder == endInorder && *rootInorder != rootValue)
throw std::exception("Invalid input.");
int leftLength = rootInorder - startInorder;
int* leftPreorderEnd = startPreorder + leftLength;
if(leftLength > 0)
{
// 构建左子树
root->m_pLeft = ConstructCore(startPreorder + 1, leftPreorderEnd,
startInorder, rootInorder - 1);
}
if((leftLength+ startPreorder)< endPreorder ) {
// 构建右子树
root->m_pRight = ConstructCore(leftPreorderEnd + 1, endPreorder,
rootInorder + 1, endInorder);
}
return root;
}
BinaryTreeNode* Construct(int* preorder,int* inorder, int length)
{
if(preorder == NULL || inorder == NULL || length <= 0)
return NULL;
return ConstructCore(preorder, preorder + length - 1,
inorder, inorder + length - 1);
}
注:《剑指offer》学习总结
- 七:重建二叉树(根据先序遍历(或者后序遍历)和中序遍历重建二叉树)
- 根据先序和中序遍历重建二叉树
- 1935. 二叉树重建(根据先序遍历和中序遍历重建二叉树并进行广度优先遍历)
- 二叉树重建 - (先序遍历、中序遍历、后序遍历)
- 根据二叉树的先序遍历和中序遍历重建二叉树
- 根据后序和中序遍历重建二叉树
- 根据前序遍历(或者是后序遍历)和中序遍历得到的序列可以重建二叉树
- 根据二叉树中序和后序(先序)遍历结果 重建二叉树
- 根据先序遍历和中序遍历重建二叉树的两种方法
- 根据先序遍历序列和中序遍历序列重建二叉树
- 根据先序遍历数列和中序遍历数列重建二叉树
- 根据二叉树的先序和中序遍历重建二叉树
- 刷题之路----根据前序遍历和中序遍历或者后序遍历和中序遍历重建二叉树
- 根据中序遍历和后序遍历重建二叉树
- 根据前序遍历、中序遍历重建二叉树
- (剑指offer笔记)根据前序遍历和中序遍历重建二叉树
- 面试题6:重建二叉树(根据前序遍历和中序遍历)
- 根据前序遍历和中序遍历结果重建二叉树(递归方法)
- 关于使用Java代码解决兔子问题
- android 能ping通,但是不能 unable to connect to ip
- android DDMS 连接真机(己ROOT),用file explore看不到data/data文件夹的解决办法 .
- 限定EditText只能输入两位小数的两种方式
- 基于js的前端开发框架对比
- 七:重建二叉树(根据先序遍历(或者后序遍历)和中序遍历重建二叉树)
- 树的定义及术语
- ehcache显示文章阅读次数相关思考
- 论文提要“Delving Deep into Rectifiers”
- Android多线程编程小结
- 禁止ScrollView在子控件的布局改变时自动滚动的的方法
- 我是如何惩罚骗子的
- Android GridView添加Header和Footer组件
- UVa 11475 - Extend to Palindrome