【优先级队列(堆)】2.数据流中的第 K ⼤元素(easy)

优先级队列(堆)

2.数据流中的第 K ⼤元素(easy)

题⽬链接:703. 数据流中的第 K ⼤元素

题⽬描述:

设计⼀个找到数据流中第 k ⼤元素的类(class)。注意是排序后的第 k ⼤元素,不是第 k 个不同的元素。

请实现 KthLargest 类:

KthLargest(int k, int[] nums) 使⽤整数 k 和整数流 nums 初始化对象。

int add(int val) 将 val 插⼊数据流 nums 后,返回当前数据流中第 k ⼤的元素。

⽰例:

输⼊:

"KthLargest", "add", "add", "add", "add", "add"

\[3, \[4, 5, 8, 2\]\], \[3\], \[5\], \[10\], \[9\], \[4\]

输出:

null, 4, 5, 5, 8, 8

解释:

KthLargest kthLargest = new KthLargest(3, [4, 5, 8, 2]);

kthLargest.add(3); // return 4

kthLargest.add(5); // return 5

kthLargest.add(10); // return 5

kthLargest.add(9); // return 8

kthLargest.add(4); // return 8

提⽰:

1 <= k <= 10^4

0 <= nums.length <= 10^4

-104 <= nums[i] <= 10^4

-104 <= val <= 10^4

最多调⽤ add ⽅法 10^4 次

题⽬数据保证,在查找第 k ⼤元素时,数组中⾄少有 k 个元素

解法(优先级队列):

算法思路:

我相信,看到 TopK 问题的时候,兄弟们应该能⽴⻢想到「堆」,这应该是刻在⻣⼦⾥的记忆。

算法代码:

java 复制代码
class KthLargest
{
 // 创建⼀个⼤⼩为 k 的⼩根堆
 PriorityQueue<Integer> heap;
 int _k;
 public KthLargest(int k, int[] nums) 
 {
	 _k = k;
	 heap = new PriorityQueue<>();
	 for(int x : nums)
	 {
		 heap.offer(x);
		 if(heap.size() > _k)
		 {
		 	heap.poll();
		 }
	 }
 }
 
 public int add(int val) 
 {
	 heap.offer(val);
	 if(heap.size() > _k)
	 {
	 	heap.poll();
	 }
	 return heap.peek();
 }
}
/**
 * Your KthLargest object will be instantiated and called as such:
 * KthLargest obj = new KthLargest(k, nums);
 * int param_1 = obj.add(val);
 */
相关推荐
jr-create(•̀⌄•́)24 分钟前
正则化和优化算法区别
pytorch·深度学习·神经网络·算法
li星野2 小时前
刷题:数组
数据结构·算法
tankeven2 小时前
HJ182 画展布置
c++·算法
CS_Zero4 小时前
无人机路径规划算法——EGO-planner建模总结—— EGO-planner 论文笔记(一)
论文阅读·算法·无人机
杰梵4 小时前
聚酯切片DSC热分析应用报告
人工智能·算法
@BangBang4 小时前
leetcode (4): 连通域/岛屿问题
算法·leetcode·深度优先
Ulyanov4 小时前
像素迷宫:路径规划算法的可视化与实战
大数据·开发语言·python·算法
Mr_pyx4 小时前
【LeetCode Hot 100】 除自身以外数组的乘积(238题)多解法详解
算法·leetcode·职场和发展
Trouvaille ~5 小时前
零基础入门 LangChain 与 LangGraph(五):核心组件上篇——消息、提示词模板、少样本与输出解析
人工智能·算法·langchain·prompt·输入输出·ai应用·langgraph
MOON404☾5 小时前
Chapter 002. 线性回归
算法·回归·线性回归