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];
    }
};
相关推荐
m0_736919108 分钟前
模板元编程性能分析
开发语言·c++·算法
pen-ai15 分钟前
【YOLO系列】 YOLOv1 目标检测算法原理详解
算法·yolo·目标检测
2301_7657031437 分钟前
C++中的职责链模式实战
开发语言·c++·算法
StandbyTime1 小时前
《算法笔记》学习记录-第一章
c++·算法·算法笔记
近津薪荼1 小时前
优选算法——双指针8(单调性)
数据结构·c++·学习·算法
格林威1 小时前
Baumer相机铆钉安装状态检测:判断铆接是否到位的 5 个核心算法,附 OpenCV+Halcon 的实战代码!
人工智能·opencv·算法·计算机视觉·视觉检测·工业相机·堡盟相机
星空露珠1 小时前
速算24点检测生成核心lua
开发语言·数据库·算法·游戏·lua
happygrilclh2 小时前
高压高频电源的pid算法
算法
格林威2 小时前
Baumer相机铸件气孔与缩松识别:提升铸造良品率的 6 个核心算法,附 OpenCV+Halcon 实战代码!
人工智能·opencv·算法·安全·计算机视觉·堡盟相机·baumer相机
葫三生2 小时前
存在之思:三生原理与现象学对话可能?
数据库·人工智能·神经网络·算法·区块链