剑指offer-二叉树的重建(前序、中序遍历)

栏目: 数据库 · 发布时间: 8年前

内容简介:剑指offer-二叉树的重建(前序、中序遍历)

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

问题分析:递归思想处理

前序遍历顺序为:节点->左子树->右子树

中序遍历顺序为:左子树->节点->右子树

在前序遍历数组中,拿到第一个节点数据,然后在中序遍历数组中找到该节点,然后将其数组分为两部分。然后根据两部分数组在重复以上动作分别重建其左子树与右子树。

剑指offer-二叉树的重建(前序、中序遍历)

代码实现:

TreeNode* reConstructBinaryTree(vector<int> pre,vector<int> vin) {
        if(pre.empty()&&vin.empty())
            return NULL;
        TreeNode* root = new TreeNode(pre[0]);
        int pos = 0;
        for(pos;pos<vin.size();pos++)
            {
            if(pre[0] == vin[pos])
                break;
        }
        vector<int>_preleft,_vinleft,_preright,_vinright;
        for(int i = 0;i<pos;i++)
            {
            _preleft.push_back(pre[i+1]);
            _vinleft.push_back(vin[i]);
        }
        for(int j = pos+1;j<vin.size();j++)
            {
            _preright.push_back(pre[j]);
            _vinright.push_back(vin[j]);
        }
        root->left = reConstructBinaryTree(_preleft,_vinleft);
        root->right = reConstructBinaryTree(_preright,_vinright);
        
        return root;
    }

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

怪诞行为学2

怪诞行为学2

[美]丹·艾瑞里 / 赵德亮 / 中信出版社 / 2010-1-9 / 42.00元

《怪诞行为学2:非理性的积极力量》编辑推荐:尝试用“非理性”的决策方式,彻底颠覆工作和生活中的“逻辑”,你将获得意想不到的成就感与幸福感!畅销书《怪诞行为学》作者卷土重来,掀起新一轮“非理性”狂潮。 《写给中国人的经济学》作者王福重、著名行为经济学家董志勇倾情作序。 诺贝尔经济学奖得主阿克尔洛夫、《免费》作者安德森高度评价。 《纽约时报》《哈佛商业评论》《波士顿环球报》等全球顶级......一起来看看 《怪诞行为学2》 这本书的介绍吧!

随机密码生成器
随机密码生成器

多种字符组合密码

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换