【leetcode hot 100 215】数组中的第K个最大元素

解法一:维护最大最小值 -> 堆 -> k个元素的最小值堆

java 复制代码
class Solution {
    public int findKthLargest(int[] nums, int k) {
        // 维护最大最小值 -> 堆 -> k个元素的最小值堆
        PriorityQueue<Integer> heap = new PriorityQueue<>((n1, n2) -> n1 - n2);

        for (int i = 0; i < nums.length; i++) {
            heap.offer(nums[i]);
            if (heap.size() > k) {
                // 维护k个元素的最小值堆
                heap.poll();
            }
        }

        return heap.peek();
    }
}

注意:

  • 当堆元素个数大于k时,要剔除元素:heap.poll()
相关推荐
码破苍穹ovo7 分钟前
堆----3.数据流的中位数
java·数据结构·算法·力扣
Aousdu15 分钟前
算法_python_学习记录_01
python·学习·算法
2501_9272274434 分钟前
密集遮挡场景识别率↑31%!陌讯轻量化部署方案在智慧零售的实战解析
人工智能·算法·目标检测·计算机视觉·目标跟踪·零售
呼哧呼哧.1 小时前
Java 8特性(一)
java·开发语言
Runing_WoNiu1 小时前
Golang 与Java 单例模式、工厂模式比较
java·单例模式·golang
Armyyyyy丶2 小时前
Sentinel原理之责任链详解
java·sentinel·熔断限流
xingkongvv123 小时前
C# 异步编程
java·服务器·开发语言·前端·javascript
●VON4 小时前
重生之我在暑假学习微服务第十一天《配置篇》+网关篇错误订正
java·学习·微服务·云原生·暑假
运维帮手大橙子10 小时前
完整的登陆学生管理系统(配置数据库)
java·前端·数据库·eclipse·intellij-idea
王大锤·10 小时前
基于spring boot的个人博客系统
java·spring boot·后端