Leetcode 105. 从前序与中序遍历序列构造二叉树

心路历程:

第一眼看这个题有点懵,后来根据题目给的案例模拟的时候发现,其实只需要在递归函数中每一层构建一个根节点和它的左右子树即可,递归函数传入的是以当前为根节点的前序和中序遍历的数组。

前序遍历用于确认根节点,中序遍历用于确认该根节点的左右子树的长度,然后即可递归不断向下进行。

注意的点:

1、利用递归函数创建二叉树时,每一层new一个node,然后node.left = dfs(...)...,记得最后要把node给return;

2、有return值的递归函数在边界条件和函数上都需要return

3、传参想不明白索引的时候传入数组即可

解法:递归+二叉树建树

python 复制代码
# Definition for a binary tree node.
# class TreeNode:
#     def __init__(self, val=0, left=None, right=None):
#         self.val = val
#         self.left = left
#         self.right = right
class Solution:
    def buildTree(self, preorder: List[int], inorder: List[int]) -> Optional[TreeNode]:

        def dfs(prelist, inlist):  # 构建以prelist[0]为根节点的树
            if not prelist and not inlist: return None
            root = TreeNode(prelist[0])
            root_i = inlist.index(prelist[0])  # 因为值是唯一确定的
            left_len, right_len = root_i, len(inlist) - root_i
            root.left = dfs(prelist[1: 1 +left_len], inlist[:root_i] )
            root.right = dfs(prelist[1+left_len:], inlist[root_i+1:] )
            return root

        return  dfs(preorder, inorder)
相关推荐
晴空闲雲9 分钟前
数据结构与算法-树和二叉树-二叉树的存储结构(Binary Tree)
数据结构·算法
索迪迈科技2 小时前
Flink Task线程处理模型:Mailbox
java·大数据·开发语言·数据结构·算法·flink
元亓亓亓3 小时前
LeetCode热题100--230. 二叉搜索树中第 K 小的元素--中等
算法·leetcode·职场和发展
草莓熊Lotso3 小时前
《算法闯关指南:优选算法-双指针》--01移动零,02复写零
c语言·c++·经验分享·算法·leetcode
焜昱错眩..4 小时前
代码随想录算法训练营第三十九天|62.不同路径 63.不同路径ll
算法
焦耳加热7 小时前
阿德莱德大学Nat. Commun.:盐模板策略实现废弃塑料到单原子催化剂的高值转化,推动环境与能源催化应用
人工智能·算法·机器学习·能源·材料工程
wan5555cn7 小时前
多张图片生成视频模型技术深度解析
人工智能·笔记·深度学习·算法·音视频
u6068 小时前
常用排序算法核心知识点梳理
算法·排序
蒋星熠10 小时前
Flutter跨平台工程实践与原理透视:从渲染引擎到高质产物
开发语言·python·算法·flutter·设计模式·性能优化·硬件工程
小欣加油10 小时前
leetcode 面试题01.02判定是否互为字符重排
数据结构·c++·算法·leetcode·职场和发展