当前位置: 首页> 游戏> 游戏 > 不免费的网络营销方式_百度关键词优化手段_可以免费推广的平台_站长工具seo推广

不免费的网络营销方式_百度关键词优化手段_可以免费推广的平台_站长工具seo推广

时间:2025/8/1 1:18:16来源:https://blog.csdn.net/sysu63/article/details/145542535 浏览次数:0次
不免费的网络营销方式_百度关键词优化手段_可以免费推广的平台_站长工具seo推广

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

  • 题目
    • 题目描述
    • 示例 1:
    • 示例 2:
    • 提示:
  • 题解
    • 解题思路
    • python实现
    • 代码解释
    • 提交结果

题目

题目描述

给定两个整数数组 preorder 和 inorder ,其中 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
preorder 和 inorder 均 无重复 元素
inorder 均出现在 preorder
preorder 保证 为二叉树的前序遍历序列
inorder 保证 为二叉树的中序遍历序列

题解

解题思路

要根据给定的前序遍历和中序遍历数组构造二叉树,可以采用递归的方法。基本思路是:

  1. 前序遍历的第一个元素总是当前树或子树的根节点。
  2. 在中序遍历数组中找到这个根节点的位置,这样就可以知道左子树和右子树的所有节点(所有在根节点左侧的值属于左子树,右侧的属于右子树)。
  3. 对于左子树和右子树,重复上述过程,直到构建出整棵树。

python实现

以下是Python代码实现:


def buildTree(preorder, inorder):if not preorder or not inorder:return None# 前序遍历的第一个元素是根节点root_val = preorder[0]root = TreeNode(root_val)# 找到根节点在中序遍历中的位置root_index_in_inorder = inorder.index(root_val)# 递归构建左子树和右子树root.left = buildTree(preorder[1:1 + root_index_in_inorder], inorder[:root_index_in_inorder])root.right = buildTree(preorder[1 + root_index_in_inorder:], inorder[root_index_in_inorder + 1:])return root

代码解释

  • TreeNode类:定义了二叉树节点的数据结构。
  • buildTree函数
    • 首先检查preorderinorder是否为空,若为空则返回None
    • 取出preorder的第一个元素作为当前树或子树的根节点。
    • inorder数组中查找该根节点的位置,以此来确定左右子树的范围。
    • 递归地对左右子树进行相同的操作,直到构建完成整个树。
  • printTree函数:用于层次遍历输出构造的二叉树,便于验证结果。

这种方法利用了前序遍历和中序遍历的特点,通过递归的方式有效地重建原始二叉树。时间复杂度主要由查找根节点在中序数组中的位置决定,为O(n^2)最坏情况下(当树退化成链表时)。为了优化查找效率,可以使用哈希表记录每个值在中序数组中的索引,从而将查找操作的时间复杂度降低至O(1),整体算法的时间复杂度可优化为O(n)。

提交结果

在这里插入图片描述

关键字:不免费的网络营销方式_百度关键词优化手段_可以免费推广的平台_站长工具seo推广

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

责任编辑: