面试必考精华版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)

相关推荐
POLITE317 小时前
Leetcode 76.最小覆盖子串 JavaScript (Day 6)
javascript·算法·leetcode
CamilleZJ17 小时前
eslint+prettier
前端·eslint·工程化·prettier
web小白成长日记17 小时前
深入理解 React 中的 Props:组件通信的桥梁
前端·javascript·react.js
2501_9466756417 小时前
Flutter与OpenHarmony打卡步进器组件
java·javascript·flutter
tjswk200817 小时前
在ios上动态插入元素的列表使用:last-child样式可能不能及时生效
前端
小小荧18 小时前
CSS 写 SQL 查询?后端慌了!
前端·sql
小高00718 小时前
🔥3 kB 换 120 ms 阻塞? Axios 还是 fetch?
前端·javascript·面试
千寻girling18 小时前
面试官 : “ Vue 选项式api 和 组合式api 什么区别? “
前端·vue.js·面试
小二·18 小时前
从零手写《超级玛丽》——前端 Canvas 游戏开发与物理引擎
前端·游戏