当前位置: 首页 > news >正文

【LeetCode】剑指 Offer 54. 二叉搜索树的第k大节点 p269 -- Java Version

题目链接:https://leetcode.cn/problems/er-cha-sou-suo-shu-de-di-kda-jie-dian-lcof/

1. 题目介绍( 54. 二叉搜索树的第k大节点)

给定一棵二叉搜索树,请找出其中第 k 大的节点的值。

【测试用例】:
示例 1:
在这里插入图片描述
示例2:
在这里插入图片描述

【条件约束】:

限制:

  • 1 ≤ k ≤ 二叉搜索树元素个数

2. 题解

2.1 中序遍历 – O(n)

时间复杂度O(n),空间复杂度O(1)
在这里插入图片描述

解题思路】:
由于题目给的树是 二叉搜索树 ,即 具有以下性质:

  • 若它的左子树不空,则左子树上所有结点的值均小于它的根结点的值;
  • 若它的右子树不空,则右子树上所有结点的值均大于它的根结点的值;
  • 它的左、右子树也分别为二叉排序树。

……
因此,若对它进行中序遍历,则是一颗递增的排好序的序列!
在这里插入图片描述
如上图所示,这是一棵有7个节点的二叉搜索树,它的中序遍历序列为 {2,3,4,5,6,7,8}
……
该题要求我们求的是 一棵二叉搜索树的 第 k 大节点,那么就应该对应着中序遍历序列的 倒数第 k 个节点;以上面的二叉搜索树为例,第 1 大节点应为 8,第 2 大节点应为 7,依次类推,原书中的举例应该是错的,它说按节点数值大小顺序,第3大节点的值是4(感觉这里应该是说错了)
……
实现策略】:
思路理清了,我们就可以愉快的写代码了
中序倒序遍历(右、根、左)求 第 k 大,同理,中序正序遍历(左、根、右)可以用来求 第 k 小

  1. 判断无效输入:头节点是否为空,k是否小于等于0;
  2. 以递归的形式 dfs() 来进行中序倒叙遍历,按照(右、根、左) 的顺序;
  3. 定义一个全局的 计数变量 idx,用来确认当前节点是否已经到了第 k 大节点,如果是,则将值保存在 res 中;(这里进一步简化的话,可以省略掉 idx 变量,转而直接操作 k ,让 k--,当 k 减至 0 时,代表已找到目标节点,无需再继续遍历)
  4. 递归结束,返回 res .
/*** Definition for a binary tree node.* public class TreeNode {*     int val;*     TreeNode left;*     TreeNode right;*     TreeNode(int x) { val = x; }* }*/
class Solution {// Solution1:中序遍历int res,idx = 0;public int kthLargest(TreeNode root, int k) {// 无效输入判断if (root == null || k <= 0) return -1;// 递归中序遍历dfs(root,k);// 最后返回结果return res;}void dfs(TreeNode root, int k) {// 递归终止条件if(root == null) return;// 中序倒序遍历,找最大dfs(root.right,k);idx++;// 如果当前是第k大,赋值给resif(idx == k) res = root.val;// 找左子树dfs(root.left,k);}
}

在这里插入图片描述

3. 参考资料

[1] 面试题54. 二叉搜索树的第 k 大节点(中序遍历 + 提前返回,清晰图解)

http://www.lryc.cn/news/59238.html

相关文章:

  • [工具类] post请求 获取request对象, 获取request的请求体(body)参数
  • Golang 多版本安装小工具G
  • day29—选择题
  • day8 互斥锁/读写锁的概念及使用、死锁的避免
  • 2023-04-13 monetdb-str类型变长存储-分析
  • 011:Mapbox GL两种方式隐藏logo和版权,个性化版权的声明
  • 结合PCA降维的DBSCAN聚类方法(附Python代码)
  • 限流:计数器、漏桶、令牌桶 三大算法的原理与实战(史上最全)
  • Redis用于全局ID生成器、分布式锁的解决方案
  • OpenTex 企业内容管理平台
  • 【0基础学爬虫】爬虫基础之数据存储
  • Redis与本地缓存组合使用(IT枫斗者)
  • 手把手教你学习IEC104协议和编程实现 十 故障事件与复位进程
  • 浅析分布式理论的CAP
  • 使用 TensorFlow 构建机器学习项目:6~10
  • 使用 LXCFS 文件系统实现容器资源可见性
  • SQL LIMIT
  • OpenCV实战之人脸美颜美型(六)——磨皮
  • Java技术栈—重装系统后不重新安装也能正常使用的设置方式
  • 智驾升级!ADB+AFS「起势」
  • 算法记录 | Day27 回溯算法
  • 性能测试总结-根据工作经验总结还比较全面
  • 类型断言[as语法 | <> 语法
  • barret reduction原理详解及硬件优化
  • NLP / LLMs中的Temperature 是什么?
  • c#快速入门~在java基础上,知道C#和JAVA 的不同即可
  • nginx--基本配置
  • R语言中apply系列函数详解
  • 红黑树探险:从理论到实践,一站式掌握C++红黑树
  • CDH6.3.2大数据集群生产环境安装(七)之PHOENIX组件安装