nums[]第K个最大数字

本文介绍了两种方法来找到数组nums中的第K个最大数字。第一种方法是通过构建最大堆,然后进行调整,时间复杂度为O(n log n)。第二种方法是直接对数组进行排序,然后返回排序后的第K-1个元素,时间复杂度为O(n log n)。这两种方法在处理大型数据集时都有其优势。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在这里插入图片描述
法一:堆排
class Solution {public:
void maxHeapify(vector& a, int i, int heapSize) {
int l = i * 2 + 1, r = i * 2 + 2, largest = i;
if (l < heapSize && a[l] > a[largest]) { largest = l; }
if (r < heapSize && a[r] > a[largest]) { largest = r; }
if (largest != i) { swap(a[i], a[largest]);
maxHeapify(a, largest, heapSize); } }
void buildMaxHeap(vector& a, int heapSize) {
for (int i = heapSize / 2; i >= 0; --i) {
maxHeapify(a, i, heapSize); } }
int findKthLargest(vector& nums, int k) {
int heapSize = nums.size();
buildMaxHeap(nums, heapSize);
for (int i = nums.size() - 1; i >= nums.size() - k + 1; --i) {
swap(nums[0], nums[i]);
–heapSize;
maxHeapify(nums, 0, heapSize); }
return nums[0]; }};

法二:
class Solution {public:
int findKthLargest(vector& nums, int k) { sort(nums.begin(),nums.end(),greater());
return nums[k-1]; }};

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值