面试必考精华版Leetcode215. 数组中的第K个最大元素

题目:


代码(2023年10月27日首刷看解析):

cpp 复制代码
class Solution {
public:
    int findKthLargest(vector<int>& nums, int k) {
        return quickselect(nums,k);
    }

    int quickselect(vector<int>& nums,int k){
        vector<int> big,equel,small;
        int pivot = nums[rand()%nums.size()];
        for(auto num:nums){
            if(num>pivot){
                big.push_back(num);
            }else if(num<pivot){
                small.push_back(num);
            }else{
                equel.push_back(num);
            }
        }
        if(k<=big.size()){
            return quickselect(big,k);
        }
        else if(nums.size()-small.size()<k){
            return quickselect(small,k-(nums.size()-small.size()));
        }
        return pivot;
    }
};

时间复杂度为O(N)

相关推荐
贾斯汀玛尔斯16 小时前
每天学一个算法--BM25(Okapi BM25)
算法
无我Code16 小时前
全套开源:一款云端服务+本地设备计算的文生图应用
前端·人工智能·后端
用户693717500138417 小时前
实测可用|小米 MiMo 百万亿 Token 免费领,开发者速冲
前端·后端·ai编程
grant-ADAS17 小时前
Overlay套刻测量
算法
前端小万17 小时前
令人头痛的前端环境
前端·前端工程化
猿长大人17 小时前
算法 | Douglas-Peucker 拯救“腰椎间盘突出的三角形”
算法
明月_清风17 小时前
Nginx 模块机制深度解析:从核心原理到生产实践
前端·nginx
HackTorjan17 小时前
深度解析雪花算法及其高性能优化策略
人工智能·深度学习·算法·性能优化·dreamweaver
北顾笙98017 小时前
day35-数据结构力扣
数据结构·算法·leetcode
APIshop17 小时前
1688 跨境寻源通详情接口深度解析:从接入到实战
前端·网络·chrome