当前位置: 首页 > news >正文

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大的数字)。}
http://www.jsqmd.com/news/79563/

相关文章:

  • 2024年8月中文大模型战力榜:国产模型全面崛起改写全球竞争格局
  • jsonnet介绍和使用
  • Redis持久化机制详解:RDB和AOF对决,哪个更胜一筹?
  • JavaScript 与 WebAssembly 的零拷贝交互:使用共享线性内存(Linear Memory)实现超大数据传输
  • 考研408--组成原理--day7--指令扩展操作码寻址
  • C语言实现幂级数(附带源码)
  • GCC完全指南:从编译基础到高级项目构建(超详细)
  • JavaScript 全局对象 `globalThis` 的多环境统一:各引擎在实现跨环境引用时的设计权衡
  • JavaScript 的参数对象 `arguments` 与 命名参数的同步行为:在非严格模式下的内存陷阱
  • Flutter 通用弹窗组件 CustomDialogWidget:全自定义布局 + 多场景适配
  • 计算机科学与技术
  • 突破大模型推理瓶颈:阶跃星辰提出MFA机制,KV缓存降幅超93%且性能反升
  • Flutter 通用列表项组件 CommonListItemWidget:全场景布局 + 交互增强
  • 突破性图像编辑模型Qwen-Edit-2509 LoRa发布:实现精准镜头控制与多视角生成
  • XTOOL InPlus IK618 One-Year Update Service: Keep Your Diagnostics Current for European/American Cars
  • MiniCPM-Llama3-V 2.5震撼发布:重新定义多模态大模型性能边界
  • ContextMenuManager:5个立竿见影的技巧让Windows右键菜单飞起来
  • League Akari智能助手:英雄联盟玩家的游戏优化新选择
  • 视频生成效率革命:LightX2V团队发布LightVAE/TAE系列优化模型,平衡画质、速度与显存
  • [AI编程] ClaudeCode:智能体编程的最佳实践
  • 自建项目管理平台:用 Focalboard+cpolar 打破协作边界
  • 《数据库运维》 郭文明 实验1 MySQL数据库服务器配置核心操作与思路解析
  • 一文吃透API网关:核心功能详解
  • C语言递归函数的习题笔记
  • 文献综述写作期末指南:方法、结构与常见问题解析
  • JavaScript 与 硬件交互:利用 WebUSB/WebSerial API 处理二进制协议的状态机设计
  • 第53天(中等题 数据结构)
  • 如何快速掌握Scarab:空洞骑士模组管理的完整指南
  • Qwen3-8B-Base震撼发布:82亿参数如何颠覆大模型效率规则?【开源下载通道】
  • 腾讯混元开源突破性工具:HunyuanVideo-Foley实现电影级音效一键生成,多项指标刷新SOTA