LeetCode:74.数组中的第K个最大元素

目录

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


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

这道题通过堆排序解决,我们建立一个最大堆,将堆顶的K - 1个元素删除,留下的就是第K大的

cpp 复制代码
class Solution {
public:
    void maxHeap(vector<int>& nums, int parent, int heapsize)
    {
        int left = parent * 2 + 1, right = parent * 2 + 2;
        int maxsum = parent;
        if(left < heapsize && nums[left] > nums[maxsum]) maxsum = left;
        if(right < heapsize && nums[right] > nums[maxsum]) maxsum = right;
        if(maxsum != parent)
        {
            swap(nums[maxsum], nums[parent]);
            maxHeap(nums, maxsum, heapsize);
        }
    }
    
    void buildMaxHeap(vector<int>& nums, int heapsize)
    {
        for(int i = heapsize; i >= 0; i--)
            maxHeap(nums, i, heapsize);
    }

    int findKthLargest(vector<int>& 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;
            maxHeap(nums, 0, heapsize);
        }
        return nums[0];
    }
};
相关推荐
炽烈小老头7 小时前
【每天学习一点算法 2026/01/09】3的幂
学习·算法
渡我白衣7 小时前
计算机组成原理(14):算术逻辑单元ALU
大数据·人工智能·算法·机器学习·计组·数电·alu
柳鲲鹏7 小时前
OpenCV视频实时跟踪目标,多种算法,python版
opencv·算法·音视频
朱峥嵘(朱髯)7 小时前
数据库如何根据估计 NDV,以及通过分区 NDV 推导全局 NDV
数据库·算法
山上三树7 小时前
详细介绍 C 语言 typedef 及与 #define 的核心对比
c语言·数据结构·算法
释怀°Believe7 小时前
Daily算法刷题【面试经典150题-7️⃣位运算/数学/】
算法·面试·职场和发展
2401_876221347 小时前
因数个数、因数和、因数积
c++·算法
云里雾里!7 小时前
LeetCode 744. 寻找比目标字母大的最小字母 | 从低效到最优的二分解法优化
算法·leetcode
一条大祥脚8 小时前
26.1.3 快速幂+容斥 树上dp+快速幂 带前缀和的快速幂 正序转倒序 子序列自动机 线段树维护滑窗
数据结构·算法
二狗哈8 小时前
czsc入门5: Tick RawBar(原始k线) NewBar (新K线)
算法·czsc