前序和中序序列重建二叉树

思路

根据前序和中序的特性,前序序列的一个元素就是树的根元素,那么在中序序列找到相应的元素。找到后该元素前面所有元素都是左子树元素,后面元素都是右子树元素。那么此时跟节点的pleft就是左子树返回的结果,pright就是右子树返回的结果,使之递归即可,递归出口就是前序区间只有一个元素时。
这里写图片描述

Node* _rebuilt_In_pre_order(int *prestart, int*preEnd, int*Instart, int*InEnd)
{
    int *left_end = Instart;
    Node*Root = new Node(prestart[0]);
    if (prestart == preEnd)
    {
        if(Instart==InEnd&&prestart[0] == Instart[0]) 
            return Root;
       else {
        cerr << "输入有误" << endl;
        exit(1);
      }
    }
    while (left_end <= InEnd&&prestart[0] != *left_end)
    {
        left_end++;
    }
    if (left_end > InEnd){
        cerr << "输入有误" << endl;
        exit(2);
    }
    int left_length = left_end - Instart;
    int *left_pre_end = prestart + left_length;
    if (left_length>0)
    {
        Root->_PLeft = _rebuilt_In_pre_order(prestart+1, left_pre_end, Instart, left_end - 1);//将左子树区间输入该函数,返回一个左子树的节点出来赋值给根的左
    }
    if (left_end < InEnd)
    {
        Root->_PRight = _rebuilt_In_pre_order(prestart + 1 + left_length, preEnd, left_end + 1, InEnd);
    }
    return Root;
}
Node *rebuilt_In_pre_order(int * pre, int * In, int length)
{
    if (pre == NULL || In == NULL || length <= 0)
        return NULL;
    return _rebuilt_In_pre_order(pre, pre + length - 1, In, In + length - 1);
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值