关于二叉树的概念,想必大家基本上都已经很清楚了,那么在这里我就不再一一赘述了。那么请看下面这道题:
如果已知某二叉树的前序遍历结果为{1,2,4,7,3,5,6,8},中序遍历序列为{4,7,2,1,5,3,8,6},求此重建后的二叉树。
1、实现思路:
我们都知道前序遍历是先访问根节点,然后是左子树,接着是右子树,因此在前序遍历序列中,第一个节点值就是根结点的值。但是在中序遍历中根节点是处在序列的中间,左子树的节点的值是位于根节点的左边,右子树的节点的值位于根结点值的右边,因此我们可以通过扫描中序遍历的序列来确定根节点的值和它的右子树和左子树。
分析过程如下图所示:
具体的代码实现如下图所示:
#include
<iostream>
using
namespace
std;
//结点信息
struct
BinaryTreeNode
{
int
_value;
BinaryTreeNode
* _left;
BinaryTreeNode
* _right;
};
BinaryTreeNode
* RebuiltTree(
int
*
preorder
,
int
*
inorder
,
int
length
)
{
//判空
if
(
preorder
==
NULL