重建二叉树

重建二叉树

题目

输入二叉树的先序遍历和中序遍历,重建一课二叉树

代码

#include<iostream>
#include<vector>
using namespace std;

/* Definition for binary tree*/
struct TreeNode {
    int val;
    TreeNode *left;
    TreeNode *right;
    TreeNode(int x) : val(x), left(NULL), right(NULL) {}
};

class Solution {
public:
    TreeNode* reConstructBinaryTree(vector<int> pre, vector<int> vin) {
        TreeNode *root=new TreeNode(pre[0]);//必须使用new或malloc,否则局部变量会在下一循环被删除
        vector<int> vinLeft, vinRight;
        bool isLeft = true;
        //根据前序pre第一个元素将中序分成两部分
        for (int i = 0; i<vin.size(); i++){
            if (vin[i] == pre[0]){
                isLeft = false;
                continue;
            }
            if (isLeft) vinLeft.push_back(vin[i]);
            else vinRight.push_back(vin[i]);
        }
        vector<int> preLeft, preRight;
        //根据中序左右两部分大小将前序分成两部分
        for (int i = 1; i<pre.size(); i++){
            if (i <= vinLeft.size()) preLeft.push_back(pre[i]);
            else preRight.push_back(pre[i]);
        }
        //左子树迭代
        if (vinLeft.size() == 0) root->left = NULL;
        else root->left = reConstructBinaryTree(preLeft, vinLeft);
        //右子树迭代
        if (vinRight.size() == 0) root->right = NULL;
        else root->right = reConstructBinaryTree(preRight, vinRight);
        return root;
    }
};
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值