news 2026/6/23 21:25:33

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/6/23 20:28:53

C语言实现hashmap(附带源码)

一、项目背景详细介绍哈希表&#xff08;Hash Table&#xff09;是计算机科学中最重要的数据结构之一&#xff0c;用于在平均 O(1) 时间内实现插入、删除和查找操作。几乎所有现代语言的字典/映射&#xff08;Map&#xff09;都由哈希表或基于树的结构实现。理解哈希表的实现不…

作者头像 李华
网站建设 2026/6/23 9:32:33

jsonnet介绍和使用

文章目录Jsonnet介绍一、Jsonnet 的核心特点二、基本语法示例1. 变量与局部作用域2. 函数3. 条件表达式4. 对象继承与覆盖5. 数组与列表推导三、典型使用场景✅ 配置文件管理&#xff08;如 Kubernetes、Terraform&#xff09;✅ 生成结构化数据&#xff08;JSON/YAML&#xff…

作者头像 李华
网站建设 2026/6/23 20:28:53

喜马拉雅音频数据采集:API接口分析与加密音频链接解密实战

目录 引言 项目目标 效果展示 网站抓包分析过程 抓包分析:探索喜马拉雅API的多层结构 第一步:打开网络监控,观察数据流动 第二步:分析请求参数,理解数据交换规则 第三步:解密认证机制,掌握访问控制策略 第四步:理解音频链接加密机制,掌握解密流程 第五步:解…

作者头像 李华
网站建设 2026/6/23 20:27:10

角色影像生成新纪元:Pony V7-Base引领AI创作革命

在人工智能驱动的视觉创作领域&#xff0c;角色生成技术正经历前所未有的突破。PurpleSmartAI最新发布的Pony V7-Base模型&#xff0c;凭借创新的AuraFlow架构和千万级精选训练数据&#xff0c;重新定义了角色影像生成的品质标准。这款集解剖学精准度、风格多样性与操作便捷性于…

作者头像 李华
网站建设 2026/6/23 20:28:51

论文格式修改排名:9大平台+在线一键优化

论文格式修改排名&#xff1a;9大平台在线一键优化 论文格式优化工具核心对比 工具名称 核心功能 适用场景 处理速度 特色优势 aibiye 全自动格式规范 毕业论文格式标准化 5-10分钟 支持中英文混排自动调整 aicheck 智能排版查重 学术论文格式优化 15-20分钟 图表…

作者头像 李华
网站建设 2026/6/23 16:55:15

论文写作效率低?十大AI生成平台,AIGC降重+赶due不熬夜

论文写作效率低&#xff1f;十大AI生成平台&#xff0c;AIGC降重赶due不熬夜 &#xfffd;&#xfffd; 十大AI工具对比表&#xff08;快速概览&#xff09; 工具名称 主要功能 处理时间 适配平台 独特优势 Aibiye 降AIGC率 约20分钟 知网、格子达、维普 精准调整表达…

作者头像 李华