老卫带你学---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]
相关推荐
希望有朝一日能如愿以偿8 分钟前
力扣每日一题:统计梯形的数目
算法·leetcode·职场和发展
jyyyx的算法博客2 小时前
LeetCode 面试题 16.22. 兰顿蚂蚁
算法·leetcode
Q741_1472 小时前
C++ 高精度计算的讲解 模拟 力扣67.二进制求和 题解 每日一题
c++·算法·leetcode·高精度·模拟
leoufung3 小时前
LeetCode 98 Validate Binary Search Tree 深度解析
算法·leetcode·职场和发展
jyyyx的算法博客3 小时前
LeetCode 面试题 16.18. 模式匹配
算法·leetcode
ada7_4 小时前
LeetCode(python)——94.二叉
python·算法·leetcode·链表·职场和发展
逝雪Yuki4 小时前
简单多源BFS问题
算法·leetcode·bfs·广度优先遍历
CoderYanger5 小时前
C.滑动窗口-越长越合法/求最短/最小——2904. 最短且字典序最小的美丽子字符串
java·开发语言·数据结构·算法·leetcode·1024程序员节
CoderYanger5 小时前
A.每日一题——2141.同时运行N台电脑的最长时间
java·算法·leetcode·职场和发展·1024程序员节
橘颂TA6 小时前
【剑斩OFFER】算法的暴力美学——Z字行变换
算法·leetcode·职场和发展·结构与算法