news 2026/6/24 1:34:51

LeetCode(python)——105.从前序与中序遍历序列构造二叉树

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
LeetCode(python)——105.从前序与中序遍历序列构造二叉树

题目

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

示例 1:

输入:preorder = [3,9,20,15,7], inorder = [9,3,15,20,7]输出:[3,9,20,null,null,15,7]

示例 2:

输入:preorder = [-1], inorder = [-1]输出:[-1]

提示:

  • 1 <= preorder.length <= 3000
  • inorder.length == preorder.length
  • -3000 <= preorder[i], inorder[i] <= 3000
  • preorderinorder无重复元素
  • inorder均出现在preorder
  • preorder保证为二叉树的前序遍历序列
  • inorder保证为二叉树的中序遍历序列

思路

1.前序序列——找根

2.中序序列——划分左右子树

3.递归遍历

具体步骤:
(1)递归结束条件:如果前序or中序序列为空,说明已遍历结束,return None

(2)创建根节点:取前序序列的第一个元素

(3)分左右子树:

  • 在inorder中找根节点的索引值
  • 根据这个索引值将preorder和inorder拆分成左右两个子树
  • left_in = inorder[:root_index],right_in = inorder[root_index + 1:]
  • left_pre = preorder[1:len(root_index) + 1],right_pre = preorder[len(root_index)+1,:]
  • 递归处理左右子树

代码

# 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]: if not preorder or not inorder: # 如果序列为空,return None return None root_val = preorder[0] # 取根节点 root = TreeNode(root_val) root_idx = inorder.index(root_val) # 在中序中找根节点索引 left_in = inorder[:root_idx] # 根据根节点索引划分左右子树 right_in = inorder[root_idx + 1:] left_pre = preorder[1: len(left_in) + 1] right_pre = preorder[len(left_in) + 1:] root.left = self.buildTree(left_pre, left_in) # 递归处理左右子树 root.right = self.buildTree(right_pre, right_in) return root
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/23 15:27:14

构建动态响应式动画架构:lottie-ios与现代数据流技术融合实践

构建动态响应式动画架构&#xff1a;lottie-ios与现代数据流技术融合实践 【免费下载链接】lottie-ios airbnb/lottie-ios: Lottie-ios 是一个用于 iOS 平台的动画库&#xff0c;可以将 Adobe After Effects 动画导出成 iOS 应用程序&#xff0c;具有高性能&#xff0c;易用性和…

作者头像 李华
网站建设 2026/6/23 0:56:44

小程序商城搭建 自带拼团砍价功能 快速引爆销量

小程序商城搭建的核心技术框架微信小程序开发基础&#xff1a;WXML/WXSS/JavaScript后端技术选型&#xff1a;Node.js/Python&#xff08;Django/Flask&#xff09;或PHP&#xff08;ThinkPHP/Laravel&#xff09;数据库设计&#xff1a;MySQL/MongoDB存储用户、订单、拼团数据…

作者头像 李华
网站建设 2026/6/23 17:11:52

海外网红营销:超越促销,用“圣诞故事”绑定品牌情感

每到圣诞季&#xff0c;全球品牌都会涌入折扣大战&#xff0c;但真正能在用户心里留下印记的&#xff0c;往往不是促销力度&#xff0c;而是能让消费者“感同身受”的情绪触点。圣诞节承载着人们对家庭、传统、温暖、陪伴与仪式感的期待&#xff0c;而海外网红营销真正的价值&a…

作者头像 李华
网站建设 2026/6/23 10:47:27

Qwen3-32B双模式大模型:重构企业AI效率的范式革命

Qwen3-32B双模式大模型&#xff1a;重构企业AI效率的范式革命 【免费下载链接】Qwen3-32B Qwen3-32B具有以下特点&#xff1a; 类型&#xff1a;因果语言模型 训练阶段&#xff1a;训练前和训练后 参数数量&#xff1a;32.8B 参数数量&#xff08;非嵌入&#xff09;&#xff1…

作者头像 李华
网站建设 2026/6/23 11:25:05

9、深入探索AppStack:创建、分配、测试与管理全流程

深入探索AppStack:创建、分配、测试与管理全流程 1. AppStack分配与测试 AppStack分配 为已创建的AppStack完成分配后,重复此过程,将其他AppStack分配给示例实验室中的不同Active Directory组: Evernote和VLC媒体播放器AppStack分配给销售组。 OpenOffice AppStack分配给…

作者头像 李华