老卫带你学---leetcode刷题(215. 数组中的第K个最大元素)

215. 数组中的第K个最大元素

问题:

给定整数数组 nums 和整数 k,请返回数组中第 k 个最大的元素。

请注意,你需要找的是数组排序后的第 k 个最大的元素,而不是第 k 个不同的元素。

你必须设计并实现时间复杂度为 O(n) 的算法解决此问题。

bash 复制代码
示例 1:

输入: [3,2,1,5,6,4], k = 2
输出: 5
bash 复制代码
示例 2:

输入: [3,2,3,1,2,4,5,5,6], k = 4
输出: 4
bash 复制代码
提示:

1 <= k <= nums.length <= 105
-104 <= nums[i] <= 104

解决:

堆排序

对每个元素入堆,然后pop出来k-1个

这里需要注意,默认堆为最小堆,所以在入堆的时候入num的负数,就会trick为最大堆

python 复制代码
import heapq
class Solution:
    def findKthLargest(self, nums: List[int], k: int) -> int:
        l = []
        for num in nums:
            heapq.heappush(l,-num)
            print(l)
        for _ in range(k-1):
            heapq.heappop(l)
        return -l[0]
相关推荐
圣保罗的大教堂2 小时前
leetcode 1855. 下标对中的最大距离 中等
leetcode
脱氧核糖核酸__6 小时前
LeetCode热题100——234.回文链表(两种解法)
c++·算法·leetcode·链表
生信研究猿6 小时前
leetcode 416. 分割等和子集
算法·leetcode·职场和发展
6Hzlia7 小时前
【Hot 100 刷题计划】 LeetCode 24. 两两交换链表中的节点 | C++ 精准指针舞步
c++·leetcode·链表
踩坑记录10 小时前
leetcode 92. 反转链表 II 区间反转(不是整条链表反转)
leetcode·链表
6Hzlia11 小时前
【Hot 100 刷题计划】 LeetCode 148. 排序链表 | C++ 归并排序自顶向下
c++·leetcode·链表
im_AMBER11 小时前
Leetcode 162 除了自身以外数组的乘积 | 接雨水
开发语言·javascript·数据结构·算法·leetcode
啊哦呃咦唔鱼11 小时前
leetcodehot100-347. 前 K 个高频元素
数据结构·算法·leetcode
玛丽莲茼蒿11 小时前
Leetcode hot100 多数元素【简单】
算法·leetcode·职场和发展
AbandonForce11 小时前
Map类:pair键值对|map的基本操作|operator[]
开发语言·c++·算法·leetcode