千家信息网

LeetCode怎么找出二叉搜索树中第K小的元素

发表于:2024-11-17 作者:千家信息网编辑
千家信息网最后更新 2024年11月17日,这篇文章主要介绍LeetCode怎么找出二叉搜索树中第K小的元素,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!1,问题简述给定一个二叉搜索树,编写一个函数 kthSmalles
千家信息网最后更新 2024年11月17日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安全错误 数据库的锁怎样保障安全 极光面板怎么添加服务器 残疾人人口基础数据库管理 赛尔号手游为什么没有服务器 文明讲座网络安全的观后感 网络安全知多少演讲视频 虹口区即时网络技术零售价 潜山网络安全 财务管理数据库设计 政府应对网络安全 中国自己的数据库数据库技术 苏州共营互联网科技 酷酷云物理服务器适用于哪些行业 校园网络安全文明教育会议记录 网络安全人员配备 最新版本绝地求生怎么切换服务器 国外的代理服务器网站 金融押运平台软件开发公司 开展网络安全进社区 幼儿园网络安全教育环境创设 光合网络技术服务 第一季度网络安全工作会议 三级数据库和网络技术那个好 苹果xr出现无法验证服务器身份 国有互联网科技企业 电脑出现远程服务器授权失败 prs 国家风险数据库 网络安全法的网络安全是指 华为服务器告警码10F 贵州有多少大数据服务器云主机 软件开发生意怎么样
0