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

LCR 076. 数组中的第 K 个最大元素

一、题目描述

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

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

示例 1:

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

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

提示:

1 <= k <= nums.length <= 104
-104 <= nums[i] <= 104

二、题目解析

1、插入排序

class Solution {public int findKthLargest(int[] nums, int k) {insertSort(nums);return nums[k - 1];}public void insertSort(int[] nums) {for(int i = 1;i < nums.length;i++){int target = nums[i];int j = i - 1;;for(;j >= 0;j--){if(nums[j] < target){nums[j+1] = nums[j];}else{//找到第一个大于待排元素的元素break;}            }//注意此处不能为nums[j+1] = nums[i],因为在交换过程中nums[i]被改变nums[j+1] = target;}}
}

2、快速排序思想1(一次扫描交换一个到目标位置)
左指针指向i=0,待排元素,(循环遍历前存储待排元素)
右指针指向j=length-1,最后一个元素。
从j位置往前遍历,找到大于待排元素,把该元素换到左指针指向位置(此时右指针位置废弃);
从i位置往后遍历,找到小于待排元素,把该元素换到右指针指向位置(上轮的废弃位置;且此时左指针位置废弃,下一轮遍历将交换到该位置);
再从j位置往前遍历,以此类推。
在此过程中,i走过的区域都是大于等于待排元素的,j走过的区域都是小于待排元素的,最后i和j相遇且指向的都是废弃元素。直接把待排元素排到这里即可。

class Solution {public int findKthLargest(int[] nums, int k) {quickSort(nums,0,nums.length - 1);return nums[k-1];}public void quickSort(int[] nums,int start,int end){//递归结束条件if(start >= end){return;}int mid = (start + end) / 2;swap(nums,start,mid);int index = partition(nums,start,end);quickSort(nums,start,index - 1);quickSort(nums,index + 1,end);}public int partition(int[] nums,int start,int end) {int i = start,j = end;int target = nums[start];while(i < j){while(nums[j] < target && i < j){j--;}nums[i] = nums[j];while(nums[i] >= target && i < j){i++;}nums[j] = nums[i];}//最后return i或者j位置上的元素都可以,因为打破while的时候i==jnums[j] = target;return j;}public void swap(int[] nums,int i,int j){int temp = nums[j];nums[j] = nums[i];nums[i] = temp;}
}

在这里插入图片描述
3、快速排序思想2(一次扫描交换两个到目标位置)

http://www.dtcms.com/a/333366.html

相关文章:

  • 代码随想录刷题Day33
  • [优选算法专题二滑动窗口——长度最小的子数组]
  • 【完整源码+数据集+部署教程】电池柱状态检测系统源码和数据集:改进yolo11-TADDH
  • 华为交换机配置文件的相关命令和用法
  • 深入解析五大通信协议:TCP、UDP、HTTP_HTTPS、WebSocket与GRPC
  • Linux:套接字
  • shell脚本实现sha256sum校验并拷贝校验通过的文件
  • 从模拟实现插入去理解AVL树的旋转平衡
  • 波浪模型SWAN学习(1)——模型编译与波浪折射模拟(Test of the refraction formulation)
  • 为什么哈希表(字典)的查询速度有时会突然变慢
  • 2025世界职业院校技能大赛汽车制造与维修赛道(中职组)参赛指南
  • 提升化工制造质量的 7 种方法
  • 制造企业仓储管理焕新!金指云 “一物一码” 破解混乱难题,库存成本直降 30%
  • Spring 条件注解与 SPI 机制(深度解析)
  • 焊接机器人保护气体效率优化
  • 0100题解
  • 【大模型评估体系简介】
  • Linux 系统中网络管理
  • 企业现金流综合分析报告
  • Mybatis简单练习注解sql和配置文件sql+注解形式加载+配置文件加载
  • KNN算法:从电影分类到鸢尾花识别
  • Linux运维新手的修炼手扎之第29天
  • C++中的适配器模式:灵活应对接口不兼容问题
  • JSX 与 JavaScript 的关系:从语法糖到生态系统
  • JavaWeb 欢迎页设置详解
  • 从 “碳足迹“ 到 “零碳圈“:上海零碳园区的改造密码
  • 容器技术:轻量虚拟化的未来
  • 状态流程框架(cola-component-statemachine)
  • 基于机器视觉的车道线检测与跟踪关键技术研究
  • GitHub 上 Star 数量前 18 的开源 AI Agent 项目