代码随想录day23(2)二叉树:从中序与后序遍历序列构造二叉树(leetcode106)

题目要求:根据一棵树的中序遍历与后序遍历构造二叉树。

思路:408的经典题目,思路和手撕的思路差不多,先从后序中找到根节点,再从中序中找到此节点,然后分割成左右子树,记录一下左右子树的节点个数,再在后序中切割,继续递归处理即可。

按照卡哥的思路,可以分为六步:

1.数组大小为零的话,说明是空节点了。

2.如果不为空,那么取后序数组最后一个元素作为节点元素。

3.在中序中找到此节点,开始分割

4.分割中序数组,分为左右子树

5.分割后续数组,分为左右子树

6.递归

leetcode实战:

代码实现:

相关推荐
Mr_Xuhhh3 分钟前
递归和迭代的区别(C/C++实现)
算法
历程里程碑4 分钟前
21:重谈重定义理解一切皆“文件“及缓存区
linux·c语言·开发语言·数据结构·c++·算法·缓存
2501_901147837 分钟前
PyTorch DDP官方文档学习笔记(核心干货版)
pytorch·笔记·学习·算法·面试
Daydream.V10 分钟前
决策树三中分类标准
算法·决策树·分类
元亓亓亓12 分钟前
考研408--数据结构--day6--串
数据结构·考研··408
闲人不梦卿19 分钟前
数据结构之排序方法
数据结构·算法·排序算法
TracyCoder12319 分钟前
LeetCode Hot100(24/100)——21. 合并两个有序链表
算法·leetcode·链表
数智工坊20 分钟前
【数据结构-栈、队列、数组】3.4栈在表达式求值下-递归中的应用
数据结构
power 雀儿22 分钟前
前馈网络+层归一化
人工智能·算法
爱吃rabbit的mq24 分钟前
第10章:支持向量机:找到最佳边界
算法·机器学习·支持向量机