已知二叉树的前序与中序遍历序列,求重建后的二叉树(即是二叉树的重建)

根据给定的二叉树前序遍历{1,2,4,7,3,5,6,8}和中序遍历{4,7,2,1,5,3,8,6},通过递归算法实现重建二叉树的过程。首先找到根节点值,然后在中序遍历序列中划分左右子树的区间,分别构建左右子树。" 127955373,1155456,产品需求分析深度解析:价值导向与实战技巧,"['产品管理', '需求挖掘', '数据分析', '用户体验', '商业策略']
摘要由CSDN通过智能技术生成
        关于二叉树的概念,想必大家基本上都已经很清楚了,那么在这里我就不再一一赘述了。那么请看下面这道题:
如果已知某二叉树的前序遍历结果为{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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值