news 2026/5/6 7:29:01

LeetCode热题100--215. 数组中的第K个最大元素--中等

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
LeetCode热题100--215. 数组中的第K个最大元素--中等

题目

给定整数数组 nums 和整数 k,请返回数组中第 k 个最大的元素。

请注意,你需要找的是数组排序后的第 k 个最大的元素,而不是第 k 个不同的元素。

你必须设计并实现时间复杂度为 O(n) 的算法解决此问题。

示例 1:
输入: [3,2,1,5,6,4], k = 2
输出: 5

示例 2:
输入: [3,2,3,1,2,4,5,5,6], k = 4
输出: 4

题解

publicclassSolution{privateintquickSelect(List<Integer>nums,intk){// 随机选择基准数Randomrand=newRandom();intpivot=nums.get(rand.nextInt(nums.size()));// 将大于、小于、等于 pivot 的元素划分至 big, small, equal 中List<Integer>big=newArrayList<>();List<Integer>equal=newArrayList<>();List<Integer>small=newArrayList<>();for(intnum:nums){if(num>pivot)big.add(num);elseif(num<pivot)small.add(num);elseequal.add(num);}// 第 k 大元素在 big 中,递归划分if(k<=big.size())returnquickSelect(big,k);// 第 k 大元素在 small 中,递归划分if(nums.size()-small.size()<k)returnquickSelect(small,k-nums.size()+small.size());// 第 k 大元素在 equal 中,直接返回 pivotreturnpivot;}publicintfindKthLargest(int[]nums,intk){List<Integer>numList=newArrayList<>();for(intnum:nums){numList.add(num);}returnquickSelect(numList,k);}}

解析

出自:215. 数组中的第 K 个最大元素(分治,清晰图解)

List<Integer>less=newArrayList<>();//创建一个新的列表用于存放小于pivot的数。List<Integer>greater=newArrayList<>();//同样,用于存放大于pivot的数。for(intnum:nums){//遍历nums中的每个数字num:if(num<pivot)//如果num小于基准数,将num添加到"less"列表中;less.add(num);elseif(num>pivot)//如果num大于基准数,将num添加到"greater"列表中。greater.add(num);}// 第 k 大的数字位于 "greater" 或与其大小相同的元素中。if(k<=greater.size())//如果k小于等于"greater"的大小,说明我们正在寻找的元素在"greater"列表中。所以需要调用quickSelect函数,参数为(greater, k)。returnquickSelect(greater,k);else//否则,说明我们要找的数字不在列表 "greater" 和 "equal"(这些与基准数相等的元素)中,而在 "less" 列表中。所以将 k 减去 greater.size() 并递归调用 quickSelect(),参数为(less, k-less.size())returnquickSelect(less,k-greater.size());}publicintfindKthLargest(int[]nums,intk){List<Integer>list=newArrayList<>();//初始化一个新的ArrayList作为临时的list,用于存放数字。for(inti=0;i<nums.length;i++)//将原始数组转换为list格式进行处理。list.add(nums[i]);returnquickSelect(list,k);//返回调用quickSelect函数的值(找到第k大的数字)。}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/6 7:28:24

C语言递归函数的习题笔记

字符串逆序的递归实现&#xff08;C语言&#xff09;在C语言中&#xff0c;实现字符串逆序的递归方法是一种高效且直观的方式。递归的核心思想是将问题分解为更小的子问题&#xff1a;通过交换字符串的首尾字符&#xff0c;然后递归地处理剩余的子字符串&#xff0c;直到整个字…

作者头像 李华
网站建设 2026/5/6 7:28:24

Flutter 通用弹窗组件 CustomDialogWidget:全自定义布局 + 多场景适配

在 Flutter 开发中&#xff0c;弹窗是交互反馈、信息确认、选项选择的核心载体。原生 showDialog 存在样式固化、布局灵活度低、多按钮适配差等问题&#xff0c;重复开发易导致 APP 内弹窗风格混乱。本文封装的 CustomDialogWidget 整合 “头部 内容 按钮区” 全自定义、单选…

作者头像 李华
网站建设 2026/5/6 7:27:43

Flutter 通用列表项组件 CommonListItemWidget:全场景布局 + 交互增强

在 Flutter 开发中&#xff0c;列表是数据展示的核心载体&#xff0c;而列表项的样式统一性与灵活性直接影响开发效率与用户体验。原生 ListTile 存在图标位置固定、不支持徽章提示、自定义布局受限等问题。本文封装的 CommonListItemWidget 整合 “图标 / 图片 标题 副标题 …

作者头像 李华
网站建设 2026/5/5 8:36:47

论文目录工具排名:9大平台+自动格式调整

论文目录工具排名&#xff1a;9大平台自动格式调整 核心工具对比速览 工具名称 核心功能 处理速度 适用场景 特色优势 aibiye AI生成内容检测与降重 20分钟 学术论文降AIGC 知网/格子达/维普三平台适配 aicheck AI内容识别与优化 20分钟 混合AI内容处理 保留专业…

作者头像 李华
网站建设 2026/4/30 23:43:03

论文重复率超30%?5个降重技巧,一次降到合格线

论文重复率超30%&#xff1f;5个降重技巧&#xff0c;一次降到合格线 嘿&#xff0c;大家好&#xff01;我是AI菌。今天咱们来聊聊一个让无数学生头疼的问题&#xff1a;论文重复率飙到30%以上怎么办&#xff1f;别慌&#xff0c;我这就分享5个实用降重技巧&#xff0c;帮你一次…

作者头像 李华