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

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

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

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

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

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

java 复制代码
    private int ans;
    private int k;
    public int kthSmallest(TreeNode root, int k)

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

java 复制代码
        if(node == null || k == 0){
            return;
        }

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

java 复制代码
        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)。

附代码:

java 复制代码
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); //右
    }
}
相关推荐
北域码匠1 小时前
SHA-1算法:安全哈希原理与应用解析
算法·c#·哈希算法
手写码匠2 小时前
手写 GraphRAG:从零实现图增强检索增强生成系统
人工智能·深度学习·算法·aigc
BomanGe12 小时前
NSK重载高刚性滚珠丝杠技术详解
经验分享·算法·规格说明书
Matrix_113 小时前
手机里的计算摄影:广角形变校正算法
人工智能·算法·智能手机·计算摄影
WBluuue3 小时前
数据结构与算法:有序表(二):跳表
数据结构·c++·算法·skiplist
不好听6134 小时前
深入理解链表:线性数据结构的另一面
javascript·数据结构
x138702859574 小时前
c语言中srtlen(指针使用计算字符长度)、传值和传址调用
c语言·开发语言·算法·visual studio
海兰4 小时前
【实用程序】电商销售分析仪表盘 — 从零搭建一个AI参与的全栈数据洞察系统
人工智能·学习·算法
zwenqiyu5 小时前
P5283 [十二省联考 2019] 异或粽子题解
c++·学习·算法
wayz115 小时前
Momentum:TSI(真实强度指数)技术指标详解
算法·金融·数据分析·量化交易·特征工程