二叉树遍历:已知前序中序输出后序/已知后序中序输出前序

例子:

  • 前序:1, 2, 3, 4, 5, 6(根左右)
  • 中序:3, 2, 4, 1, 6, 5(左根右)
  • 后序:3, 4, 2, 6, 5, 1(左右根)
    1、先说根据前序中序求后序,前序总是沿着根往树的左边一直跑,所以前序遍历的前面肯定是根节点
    中序则是按照:左—–根—–右 的顺序排列,其中左,右子树按照同样的结构,所以我们可以从前序遍历的根节点入手,迅速定位中序序列的结构中左子树和右子树部分,而后序遍历无非就是:左子树,右子树,访问根。
    代码如下,
    root是前序列表中代表根节点的点的下标
    start,end是中序遍历中当前处理的树的开始与结尾
#include<iostream>  
using namespace std;  
int pre[] = {1, 2, 3, 4, 5, 6};  
int mid[] = {3, 2, 4, 1, 6, 5};  
void post(int root, int start, int end) 
{  
    if(start > end)   
        return ;  
    int i = start;  
    while(i < end && mid[i] != pre[root]) i++;  //定位根在中序的位置
    post(root + 1, start, i - 1);  //递归处理左子树
    post(root + 1 + i - start, i + 1, end);  //递归处理右子树
    //cout<<pre[root];  //访问当前树的根
    cout<<mid[i];
}  

int main() 
{  
    post(0, 0, 5);  
    return 0;  
}  

2、再说根据后序中序输出前序,中序已经说过了,中序是按照:左—–根—–右 的顺序排列,其中左,右子树按照同样的结构,后序则是按照:左——右——根的顺序,其中左,右 按照同样的结构,后序遍历的最后肯定是根节点,所以我们可以从后序序列的根节点入手,把中序给分割出左 右 根的部分,然后就可以得到前序遍历啦!
同样代码如下:
root是后序列表中代表根节点的点的下标
start,end是中序遍历中当前处理的树的开始与结尾

#include<iostream>  
using namespace std;  
int post[] = {3, 4, 2, 6, 5, 1};  
int mid[] = {3, 2, 4, 1, 6, 5};  
void pre(int root, int start, int end) 
{  
    if(start > end)   
        return ;  
    int i = start;  
    while(i < end && mid[i] != post[root]) i++;  //定位根在中序的位置
    cout<<mid[i];  //访问当前处理的树的根
    pre(root-1-(end-i), start, i - 1);  //递归处理左子树
    pre(root-1, i + 1, end);  //递归处理右子树  
}  

int main()
 {  
    pre(5, 0, 5);  
    return 0;  
}  

注意每一次递归时,准确的定位根节点所在的位置很重要。

  • 14
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值