随笔 - 165,  文章 - 0,  评论 - 4,  阅读 - 18023

题目:

//方法一,利用优先队列小顶堆greater(大顶堆是less)
class Solution {
public:
    int findKthLargest(vector<int>& nums, int k) {
        priority_queue<int, vector<int>, greater<int>> q;
        for(auto n:nums){
            q.push(n);
            if(q.size()>k) q.pop();
        }
        return q.top();
    }
};
//方法二,分治快排
class Solution {
public:
    int findKthLargest(vector<int>& nums, int k) {
        return traversal(nums, k);
    }
    int traversal(vector<int>& nums, int k){
        int base = nums[rand()%nums.size()];
        vector<int> small, equall, big;
        for(int n:nums){
            if(n>base){
                big.emplace_back(n);
            }else if(n<base){
                small.emplace_back(n);
            }else{
                equall.emplace_back(n);
            }
        }
        if(k<=big.size()) return traversal(big, k);
        else if(big.size()+equall.size()<k) return traversal(small, k-(big.size()+equall.size()));
        else return base;
    }
};
posted on   孜孜不倦fly  阅读(9)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· AI 智能体引爆开源社区「GitHub 热点速览」
· Manus的开源复刻OpenManus初探
· 写一个简单的SQL生成工具
历史上的今天:
2022-03-10 Mockingbird_pyqt5_ui修改(一)

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示