LeetCode怎么找出二叉搜索树中第K小的元素
发表于:2024-12-12 作者:千家信息网编辑
千家信息网最后更新 2024年12月12日,这篇文章主要介绍LeetCode怎么找出二叉搜索树中第K小的元素,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!1,问题简述给定一个二叉搜索树,编写一个函数 kthSmalles
千家信息网最后更新 2024年12月12日LeetCode怎么找出二叉搜索树中第K小的元素
这篇文章主要介绍LeetCode怎么找出二叉搜索树中第K小的元素,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
1,问题简述
给定一个二叉搜索树,编写一个函数 kthSmallest 来查找其中第 k 个最小的元素。
说明:你可以假设 k 总是有效的,1 ≤ k ≤ 二叉搜索树元素个数。
2,示例
示例 1:
输入: root = [3,1,4,null,2], k = 1
3
/ \
1 4
\
2
输出: 1
示例 2:
输入: root = [5,3,6,2,4,null,null,1], k = 3
5
/ \
3 6
/ \
2 4
/
1
输出: 3
3,题解思路
使用二叉树的中序遍历方式进行解决
4,题解程序
import java.util.ArrayList;
import java.util.List;
public class KthSmallestTest3 {
public static void main(String[] args) {
TreeNode t1 = new TreeNode(3);
TreeNode t2 = new TreeNode(1);
TreeNode t3 = new TreeNode(4);
TreeNode t4 = new TreeNode(2);
t1.left = t2;
t1.right = t3;
t2.right = t4;
int k = 1;
int kthSmallest = kthSmallest(t1, k);
System.out.println("kthSmallest = " + kthSmallest);
}
private static List
list = new ArrayList<>();
public static int kthSmallest(TreeNode root, int k) {
if (root == null) {
return 0;
}
dfs(root);
return list.get(k - 1);
}
private static void dfs(TreeNode root) {
if (root == null) {
return;
}
if (root.left != null) {
dfs(root.left);
}
list.add(root.val);
if (root.right != null) {
dfs(root.right);
}
}
}
5,题解程序图片版
以上是"LeetCode怎么找出二叉搜索树中第K小的元素"这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注行业资讯频道!
元素
搜索
示例
题解
内容
程序
篇文章
输入
输出
最小
有效
个数
价值
兴趣
函数
图片
小伙
小伙伴
思路
方式
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
电子商城卖家数据库
网络安全保护权益法
tbc通告服务器排名的wa
软件开发是否需要从业资格证
孝义im即时通讯软件开发
代理服务器手机
360 网络安全概念股
信息化网络安全评估
pdf打印服务器
嵌入式数据库设计
英雄联盟服务器看不懂的字符
云服务器 socket
护苗网络安全科简报
公安网络安全管理岗位干什么
服务器cpu接口
管理系统的数据库需要哪些特点
服务器建设我的世界
如何导出数据库表信息吗
初中生怎么自学网络技术
数据库监听端口占用
梦回数据库
拖拖我的家用什么软件开发的
岳阳软件开发培训班
点读笔云服务器登录失败
美国服务器一年多少
app软件开发怎么盈利
360网络安全专家张义荣视频
安徽代理服务器
27国网络安全
24u服务器机柜价格