问题:给定一个二叉搜索树(BST),找到树中第 K 小的节点。

出题人:阿里巴巴出题专家:文景/阿里云 CDN 资深技术专家。

考察点:

1. 基础数据结构的理解和编码能力

2.  递归使用

参考答案:

       5
/ \
3 6
/ \
2 4
/
 1

说明:保证输入的 K 满足 1<=K<=(节点数目)

树相关的题目,第一眼就想到递归求解,左右子树分别遍历。联想到二叉搜索树的性质,root 大于左子树,小于右子树,如果左子树的节点数目等于 K-1,那么 root 就是结果,否则如果左子树节点数目小于 K-1,那么结果必然在右子树,否则就在左子树。因此在搜索的时候同时返回节点数目,跟 K 做对比,就能得出结果了。

/**
* Definition for a binary tree node.
**/ public class TreeNode {
int val;
TreeNode left;
TreeNode right;
TreeNode(int x) { val = x; }
} class Solution {
private class ResultType { boolean found; // 是否找到 int val; // 节点数目
ResultType(boolean found, int val) {
this.found = found;
this.val = val;
}
} public int kthSmallest(TreeNode root, int k) {
return kthSmallestHelper(root, k).val;
} private ResultType kthSmallestHelper(TreeNode root, int k) {
if (root == null) {
return new ResultType(false, 0);
} ResultType left = kthSmallestHelper(root.left, k); // 左子树找到,直接返回
if (left.found) {
return new ResultType(true, left.val);
} // 左子树的节点数目 = K-1,结果为 root 的值
if (k - left.val == 1) {
return new ResultType(true, root.val);
} // 右子树寻找
ResultType right = kthSmallestHelper(root.right, k - left.val - 1);
if (right.found) {
return new ResultType(true, right.val);
} // 没找到,返回节点总数
return new ResultType(false, left.val + 1 + right.val);
}
}
历史题

如何实现一个高效的单向链表逆序输出?

求 sqrt (2)精确到小数点后 10 位

最新文章

  1. 《HTML5》 Audio/Video全解
  2. Linux 操作mysql数据库 创建库 导入、删除表
  3. XtraBackup2.3.3安装配置使用(innobakupex)
  4. ie6 iframe src=&quot;javascript:&quot; 报安全警报问题
  5. 如何用java实现使用电子邮件控制你的电脑
  6. opengl混合效果
  7. npm常用命令总结
  8. SQL Interview Question
  9. Amazon Redshift and Massively Parellel Processing
  10. activity的横屏和竖屏设置
  11. angularf封装echarts
  12. Oracle12c中性能优化&amp;amp;功能增强新特性之临时undo
  13. hdu2460 e-DCC染色缩点+暴力LCA
  14. 报错解决——Disconnected:No supported authentication methods available
  15. GridView通过RowDataBound事件获取字段值、数据源列值
  16. 卸载重装ArcGIS Enterprise 注意事项
  17. ubuntu , 笔记本合上盖子时不关机的方法。
  18. mysql zip 解压安装
  19. Python web框架 Tornado(一)基础学习
  20. EMMC与nand flash的区别

热门文章

  1. SpringMVC、SpringFox和Swagger整合项目实例
  2. go语言实现分布式锁
  3. UCOSIII事件标志组
  4. [破解版]Unity3d引擎最新稳定版本4.5.5下载(官方最新稳定版本)
  5. 虹软人脸识别SDK在网络摄像头中的实际应用
  6. 快速搭建Kerberos服务端及入门使用
  7. Minio对象存储
  8. Java精通并发-锁粗化与锁消除技术实例演示与分析
  9. linux系统编程综合练习-实现一个小型的shell程序(一)
  10. redis cluster集群的原理