189.二叉树:将有序数组转换为二叉搜索树(力扣)

代码解决

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     TreeNode *left;*     TreeNode *right;*     TreeNode() : val(0), left(nullptr), right(nullptr) {}*     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}*     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}* };*/class Solution {
public:// 辅助函数,用于递归地构建BSTTreeNode* traversal(vector<int>& nums, int left, int right){// 如果左边界大于右边界,返回空节点if (left > right) return nullptr;// 取数组的中间元素作为根节点int mid = (left + right) / 2;TreeNode* root = new TreeNode(nums[mid]);// 递归构建左子树root->left = traversal(nums, left, mid - 1);// 递归构建右子树root->right = traversal(nums, mid + 1, right);return root;}// 主函数,将排序数组转换成BSTTreeNode* sortedArrayToBST(vector<int>& nums) {// 初始化左边界和右边界int left = 0;int right = nums.size() - 1;// 调用辅助函数构建BSTTreeNode* root = traversal(nums, left, right);return root;}
};

代码使用了递归的方法。主要思路是首先找到数组的中间元素,然后以这个中间元素作为根节点,递归地在数组中构建左右子树。左子树包含数组中所有小于中间元素的元素,右子树包含所有大于中间元素的元素。

这里简要解释一下代码的工作流程:

  1. 定义一个辅助函数 traversal,它接受一个排序数组、左边界和右边界作为参数。
  2. 如果左边界大于右边界,返回空节点。
  3. 找到数组的中间元素,并以这个元素作为当前节点的值。
  4. 递归地构建左子树,左子树的元素值应小于当前节点的值,左边界为 left,右边界为 mid - 1
  5. 递归地构建右子树,右子树的元素值应大于当前节点的值,左边界为 mid + 1,右边界为 right
  6. 返回构建好的根节点。
  7. 在 sortedArrayToBST 函数中,初始化左边界和右边界,然后调用 traversal 函数构建二叉搜索树。

这个算法的时间复杂度是 O(n),其中 n 是数组中元素的数量。空间复杂度也是 O(n),因为需要存储递归调用的栈。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/31415.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

华为移动网络自动驾驶解决方案MAE和无线解决方案云的开发技术方案

华为移动网络自动驾驶解决方案MAE和无线解决方案云的开发技术方案 目录 引言华为移动网络自动驾驶解决方案MAE 2.1 概述2.2 关键技术2.3 架构设计2.4 典型应用场景2.5 开发工具和环境 华为无线解决方案云 3.1 概述3.2 关键技术3.3 架构设计3.4 典型应用场景3.5 开发工具和环境…

AI选美大赛揭晓10位入围AI佳丽

全球首届AI小姐选美大赛&#xff08;WAICAs&#xff09;于上月拉开帷幕&#xff0c;总奖池积累到1.6万英镑&#xff0c;1万余名AI创作者参与&#xff0c;报送了超过1500个AI角色参加这场比赛。WAICAs 全称是未来派世界人工智能创造者大奖&#xff0c;由 Fanvue 主办。日前&…

qt打包失败 ,应用程序无法正常启动0xc000007b解决办法

用 windeployqt 打包QT程序&#xff0c;运行时提示程序无法正常启动0xc000007b #原因&#xff1a;因本机装了多个版本的Qt&#xff0c;包括32位&#xff0c;64位的&#xff0c;在cmd下可能是环境变量原因&#xff0c;用 windeployqt 打的包无法运行 解决办法&#xff1a; 1、…

以餐厅为例,来谈谈VOC(客户之声)

VOC&#xff0c;即客户之声&#xff0c;是指通过收集和分析客户的反馈意见&#xff0c;了解他们的需求和期望&#xff0c;进而指导企业改进产品和服务。在餐厅经营中&#xff0c;VOC的应用不仅能够帮助餐厅了解顾客的口味偏好、用餐习惯&#xff0c;还能揭示服务流程中的不足和…

记录一个因 MYSQL 服务端和JDBC驱动版本不一致导致 HMS 启动失败问题

记录一个因 MYSQL 服务端和JDBC驱动版本不一致导致 HMS 启动失败问题 1. 问题现象 某运维同学安装 CDH 后 HIVE 服务报警&#xff0c;查看发现 HS2 的金丝雀检查失败&#xff0c;进一步查看发现&#xff0c;HS2 无法创建默认数据库&#xff0c;且 HMS 启动失败。遂找到笔者进…

MATLAB——数组类型(二)

文章目录 前言元胞数组元胞数组寻访元胞数组的操作合并删除变形 前言 本章记录一下元胞数组的相关操作。寻访、合并、删除、变形。 元胞数组 元胞数组概念及创建详见MATLAB——数组类型。 元胞数组寻访 元胞数组中单元与单元内容是两个不同的东西。因此寻访单元和寻访单元…

vue3中如何使用pinia -- pinia使用教程(一)

vue3中如何使用pinia -- pinia使用教程&#xff08;一&#xff09; 安装使用创建 store使用 store访问修改 store 使用组合式 api 创建 store -- setup storepinia 和 hook 的完美结合如何解决上面的问题 使用 hook 管理全局状态和 pinia 有何优缺点&#xff1f;参考小结 pinia…

上位机图像处理和嵌入式模块部署(mcu之iap升级)

【 声明&#xff1a;版权所有&#xff0c;欢迎转载&#xff0c;请勿用于商业用途。 联系信箱&#xff1a;feixiaoxing 163.com】 mcu种类很多&#xff0c;如果是开发的时候需要对固件升级&#xff0c;整体还是比较容易的。不管是dap&#xff0c;还是st-link v2、j-link&#xf…

Modbus协议转Profibus协议网关接温控表与PLC通讯

一、前言 在智能化飞速发展的时代&#xff0c;各个行业都在使用自动化系统。在智能楼宇系统中&#xff0c;温控表和PLC&#xff08;可编程逻辑控制器&#xff09;通讯是至关重要的&#xff0c;在智能楼宇系统中&#xff0c;温控表起着监测和控制室内温度的重要作用。而PLC作为…

Elasticsearch中的Term_Filter过滤器技术

文章目录 一、引言二、Term Filter的工作原理与内部机制三、Term Filter的多样化使用场景3.1 精确匹配3.2 过滤分类与标签3.3 数据范围筛选3.4 复杂查询的构建 四、Term Filter的最佳实践与应用建议4.1 避免使用分析器4.2 优化索引映射4.3 充分利用缓存4.4 持续监控性能 五、结…

【地质灾害监测实现有效预警,44人提前安全转移】

6月13日14时&#xff0c;国信华源地质灾害监测预警系统提前精准预警&#xff0c;安全转移10户44人。 该滑坡隐患点通过科学部署国信华源裂缝计、倾角加速度计、雨量计、预警广播等自动化、智能化监测预警设备&#xff0c;实现了对隐患点裂缝、位移、降雨量等关键要素的实时动态…

CyclicBarrier(应对并发问题的工具类)

CyclicBarrier 5.3.1 概述以及基本使用 CyclicBarrier的字面意思是可循环使用&#xff08;Cyclic&#xff09;的屏障&#xff08;Barrier&#xff09;。它要做的事情是&#xff0c;让一组线程到达一个屏障&#xff08;也可以叫同步点&#xff09;时被阻塞&#xff0c;直到最后…

JNPF低代码开发平台:推进供应链数字化进程

随着全球贸易的日益频繁和市场竞争的加剧&#xff0c;供应链的数字化已经成为企业提高竞争力、降低成本、提高效率的关键因素。在这个过程中&#xff0c;低代码开发平台以其高效、灵活的特点&#xff0c;成为了推动供应链数字化进程的重要工具。本文将以JNPF低代码开发平台为例…

PgSQL-添加列、字段的注释

mysql是&#xff1a; 添加列&#xff1a;--alter table 表名 add column 列名 varchar(30);ALTER TABLE p_show ADD COLUMN points VARCHAR(100) COMMENT 所需积分;---------------------------------------------------------------------------------------------添加、修改…

与神对话-2

目录 三卷书&#xff0c;它们是&#xff1a; 第一卷将主要涉及个人问题&#xff0c;聚焦在个人生活中的各种挑战和机遇。第二卷将涉及更带全球性的问题&#xff0c;这个星球上的地域政治和超自然的生活。以及这个世界正在面临的挑战。第三卷将涉及最高秩序的宇宙真理&#xf…

Jmeter性能 之 “查看结果树” 界面功能介绍

前言 查看结果树 显示所有请求响应的树&#xff0c;通过它可以查看任何请求的响应。除了显示响应之外&#xff0c;还可以查看获取响应所花费的时间以及一些响应代码。需要通过"查看结果树"来查看服务器处理请求之后的返回结果&#xff0c;分析是否存在问题 注意&am…

Typora v1.8.6解锁版安装教程 (轻便简洁的Markdown编辑器)

前言 Typora是一款轻便简洁的Markdown编辑器&#xff0c;支持即时渲染技术&#xff0c;这也是与其他Markdown编辑器最显著的区别。即时渲染使得你写Markdown就想是写Word文档一样流畅自如&#xff0c;不像其他编辑器的有编辑栏和显示栏。 一、下载地址 下载链接&#xff1a;…

传染病报卡内容——丙型

--丙型 select a.morbiditdate 发病日期, diagnosedate 诊断日期, a.deathdate 死亡日期, a.casetypequality 病例分类,a.hcvrna "HCR_RNA定量" from zl_sdmb.t_报卡记录 t, c1_infectiousv1_6 a where t.id a.fileid and t.卡片种类 传…

架构设计 - 本地热点缓存

摘要&#xff1a; 缓存体系架构&#xff1a; 一级缓存&#xff1a;JVM本地缓存 二级缓存&#xff1a;Redis集中缓存 三级缓存&#xff1a;Nginx缓存&#xff08;Proxy Cache缓存&#xff1b;Lua缓存&#xff09; Java&#xff08;或任何编程语言&#xff09;中的本地热点缓…

游戏测试工程师面试,常问的问题有哪些?

一般会在面试中了解以下方面&#xff1a; 1.游戏热情&#xff0c;理解程度 玩过哪些游戏&#xff0c;这些游戏玩过多长时间&#xff0c;玩到什么样的水平&#xff0c;在游戏里花过多少钱 你觉得游戏里&#xff0c;xxx的设计如何&#xff0c;评价一下 2.编程、测试相关 学过哪…