C++——从前序与中序遍历序列构造二叉树leetcode105

C++------从前序与中序遍历序列构造二叉树leetcode105

题目描述

给定两个整数数组 preorder 和 inorder ,其中 preorder 是二叉树的先序遍历, inorder 是同一棵树的中序遍历,请构造二叉树并返回其根节点。

preorder 和 inorder 均 无重复 元素

inorder 均出现在 preorder

preorder 保证 为二叉树的前序遍历序列

inorder 保证 为二叉树的中序遍历序列

思路

来源于leetcode官方解答,先序遍历的排布是[根节点,左子树,右子树],中序遍历的排布是[左子树,根节点,右子树],因此,从先序第一个元素可以找到中序中的根节点的位置,从而可以确定出左子树和右子树的节点数目,从而可以正确划分这一级的先序遍历的左右子树,对于左右子树内部也是对应的排列方式,因此可以考虑迭代,每次更新先序遍历和中序遍历的左右边界。

同时为了减少每次查询中序根节点位置,可以考虑将值和索引使用哈希表存放。

代码

cpp 复制代码
unordered_map<int, int> hash_map;
TreeNode* mybuildTree(vector<int> preorder, vector<int> inorder, int preorder_l, int preorder_r, int inorder_l, int inorder_r)
{
	if(preorder_l>preorder_r) return nullptr;
	int pos = hash_map[preorder[preorder_l]]; // 根节点在中序中的位置
	TreeNode* root = new TreeNode(preorder[preorder_l]);
	int left_tree_length = pos-inorder_l;
	int right_tree_length = inorder_r-pos;
	root->left = mybuildTree(preorder, inorder, preorder_l+1, preorder_l+left_tree_length, inorder_l, pos-1);
	root->right = mybuildTree(preorder, inorder, preorder_r-right_tree_length+1, preorder_r, pos+1, inorder_r);
	return root;
}
TreeNode* buildTree(vector<int> preorder, vector<int> inorder)
{
	int n = preorder.size();
	for(int i = 0; i<n; i++)
	{
		hash_map[inorder[i]] = i; // 值:索引
	}
	return mybuildTree(preorder, inorder, 0, n-1, 0, n-1);
}
相关推荐
孤寂大仙v7 分钟前
【Linux笔记】——线程同步条件变量与生产者消费者模型的实现
linux·c++·笔记
ai.Neo13 分钟前
牛客网NC276055:三根木棒能否组成三角形问题详解(ACM中的A题)
数据结构·c++·算法
少了一只鹅16 分钟前
c语言内存函数
c语言·开发语言
じ☆ve 清风°32 分钟前
滑动窗口算法详解与C++实现
开发语言·c++·算法
苕皮蓝牙土豆37 分钟前
C++ map & multimap 容器:赋值、排序、大小与删除操作
开发语言·c++
Villiam_AY43 分钟前
Go 后端中双 token 的实现模板
开发语言·后端·golang
DjangoJason1 小时前
计算机网络 : Socket编程
linux·服务器·开发语言·笔记·计算机网络
映秀小子1 小时前
C语言链表的操作
c语言·开发语言·链表
东莞呵呵1 小时前
吴恩达机器学习(1)——机器学习算法分类
算法·机器学习·分类
虾球xz1 小时前
游戏引擎学习第293天:移动Familiars
c++·学习·游戏引擎