news 2026/6/24 1:59:14

力扣刷题:数组中的第k个最大元素

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
力扣刷题:数组中的第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

解析:
这道题我参考了力扣一个大神的思路(解析链接),将快速排序改成了快速选择:
基于快速排序的分治思想,但只递归处理包含目标值的那一部分

  1. 选择基准值:从数组中选一个元素作为基准(pivot)

  2. 分区:将数组分为三部分:

    left:所有大于基准值的元素

    mid:所有等于基准值的元素

    right:所有小于基准值的元素

  3. 判断目标位置:
    如果 k ≤ left.length,说明第k大的元素在left中
    如果 k > left.length 且 k ≤ left.length + mid.length,说明第k大的元素就是基准值
    否则,第k大的元素在right中

  4. 递归处理:在相应的子数组中继续查找

/** * @param {number[]} nums * @param {number} k * @return {number} */varfindKthLargest=function(nums,k){if(nums.length<=1){returnnums[0]}constmidIndex=Math.floor(nums.length/2)constmideValue=nums[midIndex]constleft=[]constmid=[]constright=[]for(leti=0;i<nums.length;i++){if(mideValue<nums[i]){left.push(nums[i])}elseif(mideValue>nums[i]){right.push(nums[i])}else{mid.push(nums[i])}}if(k<=left.length){returnfindKthLargest(left,k)}elseif(k-left.length-mid.length<=0){returnmid[0]}else{returnfindKthLargest(right,k-left.length-mid.length)}};
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/23 9:17:47

31、SharePoint Web Parts 开发全解析

SharePoint Web Parts 开发全解析 1. Silverlight Web Parts 简介 Silverlight Web Parts 能为用户提供更丰富的界面体验。幸运的是,我们无需编写大量自定义代码来创建此类 Web Part,因为微软发布了项目扩展,其中包含 Web Part 模板。该扩展及相关文档可从 MSDN Code Gal…

作者头像 李华
网站建设 2026/6/23 19:17:29

Excalidraw AI功能本地化部署的硬件要求

Excalidraw AI功能本地化部署的硬件要求 在现代技术团队中&#xff0c;一张随手可画的草图往往比千行文档更能传达设计意图。从系统架构讨论到产品原型构思&#xff0c;可视化协作已成为工程师和设计师日常工作的核心环节。Excalidraw 以其手绘风格、轻量化体验和出色的实时协作…

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

39、SharePoint 2010 及相关工具安装与站点创建指南

SharePoint 2010 及相关工具安装与站点创建指南 1. SharePoint 2010 安装概述 SharePoint 2010 的安装分为三个步骤: 1. 预安装:完成一些先决条件和其他配置。 2. 安装 SharePoint 2010 本身。 3. 运行 SharePoint 2010 配置向导。 其中,预安装步骤在服务器和客户端安…

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

(Open-AutoGLM标准化流程首次公开):支撑千万级请求的底层架构设计

第一章&#xff1a;Open-AutoGLM标准化流程首次公开Open-AutoGLM 是新一代开源自动化生成语言模型调优框架&#xff0c;旨在统一模型训练、评估与部署的全流程标准。该框架通过模块化设计&#xff0c;将数据预处理、提示工程优化、模型微调与推理服务解耦&#xff0c;提升开发效…

作者头像 李华
网站建设 2026/6/23 19:12:50

Excalidraw AI模型版本迭代管理机制

Excalidraw AI模型版本迭代管理机制 在AI能力快速融入各类生产力工具的今天&#xff0c;一个看似简单的“用文字生成图表”功能背后&#xff0c;往往隐藏着复杂的系统工程挑战。以开源白板工具 Excalidraw 为例&#xff0c;当它引入大语言模型&#xff08;LLM&#xff09;实现自…

作者头像 李华
网站建设 2026/6/23 19:13:54

告别复杂编程:Open-AutoGLM无代码平台5大隐藏功能首次曝光

第一章&#xff1a;告别复杂编程——Open-AutoGLM无代码平台全景解析在人工智能快速普及的今天&#xff0c;开发者与业务人员之间的技术鸿沟依然显著。Open-AutoGLM应运而生&#xff0c;作为一款领先的无代码AI开发平台&#xff0c;它让非技术人员也能轻松构建、训练并部署自然…

作者头像 李华