news 2026/5/15 14:46:16

042将有序数组转换为二叉搜索树

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
042将有序数组转换为二叉搜索树

将有序数组转换为二叉搜索树

题目链接:https://leetcode.cn/problems/convert-sorted-array-to-binary-search-tree/description/?envType=study-plan-v2&envId=top-100-liked

我的解答:

public TreeNode sortedArrayToBST(int[] nums) { int length = nums.length; if(length==0){ return null; } return createTree(nums,0,length-1); } public TreeNode createTree(int[] nums, int l, int r){ if(l>r){ return null; } int mid = (l+r)/2; TreeNode cur = new TreeNode(nums[mid]); cur.left = createTree(nums,l,mid-1); cur.right = createTree(nums,mid+1,r); return cur; }

分析:代码的时间复杂度为O(n),空间复杂度为O(logn)。解题思路:为了构建平衡搜索二叉树,每次取中间位置作为根节点,这样小于根节点的节点个数与大于根节点的节点个数之差不会大于1,即可以满足每个节点的左右子树的高度相差不超过1。

看了官方题解后的解答:

//方法一:中序遍历,总是选择中间位置左边的数字作为根节点 //int mid = (left + right) / 2; //方法二:中序遍历,总是选择中间位置右边的数字作为根节点 //int mid = (left + right + 1) / 2; //方法三:中序遍历,选择任意一个中间位置数字作为根节点 //int mid = (left + right + rand.nextInt(2)) / 2;

分析:

​ 1、官方题解的三种方法的解题思路差不多,都与我的解答思路一致,唯一的区别在于,[l,r]范围内的数据个数为偶数时,根节点有两种选择,而每次根节点的选择都会影响树的结构,故官方题解给出了三种方法,分别为每次选择中间位置左边的数字作为根节点、每次选择中间位置右边的数字作为根节点、随即选择中间位置的任意一边作为根节点。

​ 2、三种方法的时间复杂度都为O(n),空间复杂度都为O(logn)。

总结

  • 本题主要需要知道“二叉搜索树的中序遍历是升序序列”,所以每次选取中间位置作为根节点,就可以保证左右子树的节点个数之差不超过1。
  • 注意:根节点的选择策略的不同,会产生不同结构的但都符合题目要求的平衡二叉搜索树。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/15 14:45:11

Taotoken的API调用稳定性在跨地域团队协作中的体现

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 Taotoken的API调用稳定性在跨地域团队协作中的体现 1. 背景与挑战 我们的技术团队负责一个需要频繁调用大模型API的智能应用开发项…

作者头像 李华
网站建设 2026/5/15 14:45:09

基于Gemini API打造自定义CLI工具:用自然语言命令提升开发效率

1. 项目概述:一个能让你用自然语言“命令”AI的CLI工具 如果你和我一样,每天在终端里敲敲打打,同时又频繁地和各种AI模型(比如Google的Gemini)打交道,那你肯定也幻想过:能不能把这两件事无缝地…

作者头像 李华
网站建设 2026/5/15 14:45:08

基于Astro与Canvas的天文星图工具:技术架构与性能优化实践

1. 项目概述:一个为天文爱好者打造的实时星图工具如果你和我一样,是个喜欢在深夜仰望星空,或者对宇宙深处充满好奇的人,那你一定有过这样的经历:用手机对着天空,想知道那颗特别亮的星星究竟是木星还是天狼星…

作者头像 李华
网站建设 2026/5/15 14:44:15

基于议会制多智能体协作框架的复杂任务决策系统设计与实现

1. 项目概述:从“独狼”到“议会”,智能体协作的新范式最近在开源社区里,一个名为team-attention/agent-council的项目引起了我的注意。这个名字本身就很有意思,直译过来是“团队注意力/代理议会”。乍一看,你可能觉得…

作者头像 李华