LeetCode 215. Kth Largest Element in an Array(数组中的第K个最大元素)

2023-12-06 04:58

本文主要是介绍LeetCode 215. Kth Largest Element in an Array(数组中的第K个最大元素),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目描述:

Find the kth largest element in an unsorted array. Note that it is the kth largest element in the sorted order, not the kth distinct element.

Example 1:

Input: [3,2,1,5,6,4] and k = 2
Output: 5

Example 2:

Input: [3,2,3,1,2,4,5,5,6] and k = 4
Output: 4

Note: 
You may assume k is always valid, 1 ≤ k ≤ array's length.

 

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

示例 1:

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

示例 2:

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

说明:

你可以假设 k 总是有效的,且 1 ≤ k ≤ 数组的长度。

 

思路:

最简单最直接的做法,就是先将数组从小到大排序,然后从后往前搜索数组中第k大的元素,当然这样做非常费时。

我们可以用快速排序的思想:

(1)选中数组中的一个元素作为支点,将小于该支点的所有元素放到其左侧,大于该支点的所有元素放到其右侧,如果该支点的右边恰巧有k-1个元素,那么这个支点就是我们要找的答案;

(2)如果支点右侧区域的元素个数大于k-1,说明我们要找的目标元素在支点的右侧,因此在右侧区域重新选择新支点,同时,目标元素依然是右侧区域的第k个最大的元素;

同理,如果支点右侧区域的元素个数小于k-1,假设为j-1,说明我们要找的目标元素在支点的左侧,因此在左侧区域重新选择新支点,而此时,目标元素是左侧区域的第k-j个最大的元素;

(3)更新支点和k值,重复步骤(1)(2),直到得到我们想要的答案

 

我们利用交换思想达到分治的目的,将问题范围缩小,宏观有序,微观无序,避免将数组中的所有元素排序,从而提到计算效率。

 

实现(C++):

方法1:暴力排序

class Solution {
public:int findKthLargest(vector<int>& nums, int k) {sort(nums.begin(), nums.end());int i;for(i=nums.size()-1; i>=nums.size()-k+1; i--){}return nums[i];}
};

 

方法2:分治

class Solution {public:int find(vector<int>& nums, int k, int begin, int end, int pivot){ //分治,交换排序,快速排序//nums:目标数组//k:寻找第k个大的元素//begin:寻找区域的起点//end:寻找区域的终点//pivot:支点if(begin==end)return nums[begin];int i=begin;int j=end;while(i<j){ //交换:将小于支点的元素放到其左侧,大于支点的元素放到其右侧while(i<j&&nums[j]>=pivot)j--;nums[i]=nums[j];while(i<j&&nums[i]<=pivot)i++;nums[j]=nums[i];}nums[i]=pivot; if(end-j==k-1) //如果支点右侧恰巧有k-1个元素,说明该支点就是我们要找的目标元素return nums[j];else if(end-j>k-1&&j+1<=end) //如果支点右侧区域的元素个数大于k-1,则继续在右侧区域寻找目标元素return find(nums, k, j+1, end, nums[j+1]);else if(end-j<k-1&&j-1>=begin) //如果支点右侧区域的元素个数小于k-1,则继续在左侧区域寻找目标元素return find(nums, k-(end-j)-1, begin, j-1, nums[begin]);return -1;}public:int findKthLargest(vector<int>& nums, int k) {int begin=0;int end=nums.size()-1;int pivot=nums[0];return find(nums, k, begin, end, pivot); }
};

 

 

这篇关于LeetCode 215. Kth Largest Element in an Array(数组中的第K个最大元素)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/460514

相关文章

Java中的数组与集合基本用法详解

《Java中的数组与集合基本用法详解》本文介绍了Java数组和集合框架的基础知识,数组部分涵盖了一维、二维及多维数组的声明、初始化、访问与遍历方法,以及Arrays类的常用操作,对Java数组与集合相... 目录一、Java数组基础1.1 数组结构概述1.2 一维数组1.2.1 声明与初始化1.2.2 访问

C# 比较两个list 之间元素差异的常用方法

《C#比较两个list之间元素差异的常用方法》:本文主要介绍C#比较两个list之间元素差异,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. 使用Except方法2. 使用Except的逆操作3. 使用LINQ的Join,GroupJoin

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方

python3如何找到字典的下标index、获取list中指定元素的位置索引

《python3如何找到字典的下标index、获取list中指定元素的位置索引》:本文主要介绍python3如何找到字典的下标index、获取list中指定元素的位置索引问题,具有很好的参考价值,... 目录enumerate()找到字典的下标 index获取list中指定元素的位置索引总结enumerat

CSS实现元素撑满剩余空间的五种方法

《CSS实现元素撑满剩余空间的五种方法》在日常开发中,我们经常需要让某个元素占据容器的剩余空间,本文将介绍5种不同的方法来实现这个需求,并分析各种方法的优缺点,感兴趣的朋友一起看看吧... css实现元素撑满剩余空间的5种方法 在日常开发中,我们经常需要让某个元素占据容器的剩余空间。这是一个常见的布局需求

MySQL JSON 查询中的对象与数组技巧及查询示例

《MySQLJSON查询中的对象与数组技巧及查询示例》MySQL中JSON对象和JSON数组查询的详细介绍及带有WHERE条件的查询示例,本文给大家介绍的非常详细,mysqljson查询示例相关知... 目录jsON 对象查询1. JSON_CONTAINS2. JSON_EXTRACT3. JSON_TA

JAVA数组中五种常见排序方法整理汇总

《JAVA数组中五种常见排序方法整理汇总》本文给大家分享五种常用的Java数组排序方法整理,每种方法结合示例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录前言:法一:Arrays.sort()法二:冒泡排序法三:选择排序法四:反转排序法五:直接插入排序前言:几种常用的Java数组排序

Java数组初始化的五种方式

《Java数组初始化的五种方式》数组是Java中最基础且常用的数据结构之一,其初始化方式多样且各具特点,本文详细讲解Java数组初始化的五种方式,分析其适用场景、优劣势对比及注意事项,帮助避免常见陷阱... 目录1. 静态初始化:简洁但固定代码示例核心特点适用场景注意事项2. 动态初始化:灵活但需手动管理代

C++中初始化二维数组的几种常见方法

《C++中初始化二维数组的几种常见方法》本文详细介绍了在C++中初始化二维数组的不同方式,包括静态初始化、循环、全部为零、部分初始化、std::array和std::vector,以及std::vec... 目录1. 静态初始化2. 使用循环初始化3. 全部初始化为零4. 部分初始化5. 使用 std::a