内容简介:剑指offer-二叉树的重建(前序、中序遍历)
题目描述:输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。假设输入的前序遍历和中序遍历的结果都不含重复的数字。假如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序序列{4,7,2,1,5,3,8,6},则重建二叉树并返回。
问题分析:递归思想处理
前序遍历顺序为:节点->左子树->右子树
中序遍历顺序为:左子树->节点->右子树
在前序遍历数组中,拿到第一个节点数据,然后在中序遍历数组中找到该节点,然后将其数组分为两部分。然后根据两部分数组在重复以上动作分别重建其左子树与右子树。
代码实现:
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; }
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
智能Web算法(第2版)
【英】Douglas G. McIlwraith(道格拉斯 G. 麦基尔雷思)、【美】Haralambos Marmanis(哈若拉玛 玛若曼尼斯)、【美】Dmitry Babenko(德米特里•巴邦科) / 达观数据、陈运文 等 / 电子工业出版社 / 2017-7 / 69.00
机器学习一直是人工智能研究领域的重要方向,而在大数据时代,来自Web 的数据采集、挖掘、应用技术又越来越受到瞩目,并创造着巨大的价值。本书是有关Web数据挖掘和机器学习技术的一本知名的著作,第2 版进一步加入了本领域最新的研究内容和应用案例,介绍了统计学、结构建模、推荐系统、数据分类、点击预测、深度学习、效果评估、数据采集等众多方面的内容。《智能Web算法(第2版)》内容翔实、案例生动,有很高的阅......一起来看看 《智能Web算法(第2版)》 这本书的介绍吧!