【优先级队列(堆)】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);
 */
相关推荐
颜酱5 小时前
图结构完全解析:从基础概念到遍历实现
javascript·后端·算法
m0_736919105 小时前
C++代码风格检查工具
开发语言·c++·算法
yugi9878385 小时前
基于MATLAB强化学习的单智能体与多智能体路径规划算法
算法·matlab
DuHz5 小时前
超宽带脉冲无线电(Ultra Wideband Impulse Radio, UWB)简介
论文阅读·算法·汽车·信息与通信·信号处理
Polaris北极星少女6 小时前
TRSV优化2
算法
代码游侠6 小时前
C语言核心概念复习——网络协议与TCP/IP
linux·运维·服务器·网络·算法
2301_763472467 小时前
C++20概念(Concepts)入门指南
开发语言·c++·算法
abluckyboy7 小时前
Java 实现求 n 的 n^n 次方的最后一位数字
java·python·算法
园小异7 小时前
2026年技术面试完全指南:从算法到系统设计的实战突破
算法·面试·职场和发展
m0_706653237 小时前
分布式系统安全通信
开发语言·c++·算法