news 2026/5/5 16:05:43

hot100 230.二叉搜索树中第K小的元素

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
hot100 230.二叉搜索树中第K小的元素

思路:中序遍历。在二叉搜索树中,中序遍历的遍历顺序就是在从小到大遍历节点值,所以遍历到的第k个节点值就是答案。每次递归完左子树,在根节点的操作中,把k减少1,表示按照中序遍历的顺序访问到了一个节点。当k变为0时,就说明找到了要找的节点的值,用一个外部变量ans记录。

1.确定递归函数的参数和返回值类型:

(1)参数:二叉树的根节点和整数k。

(2)返回值类型:返回int整数结果ans。

(3)全局变量:k表示需要搜索第k小的节点值,ans表示对应的整数结果。

private int ans; private int k; public int kthSmallest(TreeNode root, int k)

2.确定终止条件:如果节点为空或k为0,子函数dfs直接return;

if(node == null || k == 0){ return; }

3.确定单层递归的逻辑:中序遍历,根值判断k是否减为0,如果减为0则用ans记录此时的节点值。

dfs(node.left); //左 if(--k == 0){ ans = node.val; //根 } dfs(node.right); //右

4.复杂度分析:

(1)时间复杂度:O(n),其中n是二叉树的大小(节点个数)。

(2)空间复杂度:O(h),其中h是树高,递归需要O(h)的栈空间。最坏情况下树是一条链,h = n,空间复杂度退化为O(n)。

附代码:

class Solution { private int ans; private int k; public int kthSmallest(TreeNode root, int k) { this.k = k; dfs(root); return ans; } private void dfs(TreeNode node){ if(node == null || k == 0){ return; } dfs(node.left); //左 if(--k == 0){ ans = node.val; //根 } dfs(node.right); //右 } }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/3 10:05:26

私有化会议选型指南:内网流量免费、API深度对接、IM一键入会

什么是私有化音视频会议? 私有化音视频会议,是指将会议系统部署在企业自己的服务器或私有云环境中,而非使用公有云服务。所有音视频流、会议录制、参会记录等数据都存储在企业可控的基础设施内,真正做到"数据不出网、安全看…

作者头像 李华
网站建设 2026/5/4 11:56:13

让opencode+GLM-4.7+SKILL一起服务

让opencodeGLM-4.7SKILL一起服务 缘起 随着克劳德的限制越来越严,追寻一个替代品,也迫上眉睫。最近opencode冒出来了,GLM-4.7好像也风评不错,而关于prompt,也慢慢进化出了skill,这个周末,刚好来试试。 过…

作者头像 李华
网站建设 2026/5/1 3:30:39

真正的高手,都是贝叶斯主义者

有人问我:在这个黑天鹅乱飞、高不确定性、模糊混沌的世界,到底有没有一种底层逻辑,能让人稳赢? 一开始,我很想回答“没有”,后来,转念一想,如果非要说一个,那就是—— …

作者头像 李华
网站建设 2026/5/1 9:45:25

期货交易平台数据分析系统开题报告

期货交易平台数据分析系统开题报告 一、选题背景 随着金融市场全球化、数字化进程加速,期货市场作为资本市场的重要组成部分,交易量持续攀升,交易品种不断丰富,涵盖农产品、金属、能源、金融衍生品等多个领域。期货交易具有杠杆性…

作者头像 李华
网站建设 2026/5/1 17:34:37

得物Java面试被问:RocketMQ的消息轨迹追踪实现

一、核心设计理念 1.1 追踪目标 text 复制 下载 四大追踪维度: 1. 生产轨迹:消息从哪个应用、哪个机器、什么时间发送 2. 存储轨迹:消息在Broker的存储状态、投递时间 3. 消费轨迹:消息被哪个消费者、何时消费、消费结果 4. 事…

作者头像 李华
网站建设 2026/5/3 14:28:36

Flutter实战:从零实现俄罗斯方块(三)交互控制与事件处理

Flutter实战:从零实现俄罗斯方块(三)交互控制与事件处理 文章目录 Flutter实战:从零实现俄罗斯方块(三)交互控制与事件处理摘要前言一、键盘事件监听1.1 RawKeyboardListener的基本用法1.2 如何映射按键到游…

作者头像 李华