算法-重建二叉树详解编程语言

/*

	[重建二叉树]

    [题目]
	输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。
	假设输入的前序遍历和中序遍历的结果中都不含重复的数字。
	例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2,1,5,3,8,6},则重建二叉树并返回。

    [解析]
    要掌握二叉树的几种遍历方式:前,中,后序遍历。递归的构建,还要要注意递归函数的出口,指针的处理。程序假设输出是合法的。
*/

#include <iostream>
#include <vector>
#include <algorithm>

using namespace std;

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){
        if(pre.size() != vin.size())
            return NULL;

        return reConstructBinaryTreeRecursive(pre, 0, pre.size()-1, vin, 0, vin.size()-1);
    }

    TreeNode* reConstructBinaryTreeRecursive(vector<int>& pre, int iPrevLeft, int iPrevRight,
                                             vector<int>& vin, int iVinLeft, int iVinRight){
        if(iPrevLeft > iPrevRight)
            return NULL;

        int valRoot = pre[iPrevLeft];
        
        // find root in vin
        int iVinRoot = iVinLeft;
        for( ; iVinRoot<=iPrevRight; iVinRoot++){
            if(vin[iVinRoot] == valRoot)
                break;
        }

        int lenLeft = iVinRoot - iVinLeft;
        int lenRight = iVinRight - iVinRoot;

        TreeNode* pRoot = new TreeNode(valRoot);
        pRoot->left = reConstructBinaryTreeRecursive(pre, iPrevLeft+1, iPrevLeft+lenLeft, vin, iVinLeft, iVinRoot-1);
        pRoot->right = reConstructBinaryTreeRecursive(pre, iPrevLeft+lenLeft+1, iPrevRight, vin, iVinRoot+1, iVinRight);

        return pRoot;
    }
};

int main()
{
    return 0;
}

原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/tech/pnotes/15283.html

(0)
上一篇 2021年7月19日 17:36
下一篇 2021年7月19日 17:36

相关推荐

发表回复

登录后才能评论