如果对于堆不是太认识,请点击:堆的初步认识-CSDN博客

数据流与上述堆--数组中第K大元素-CSDN博客的数组区别:
数据流的数据是动态变化的,数组是写死的
堆--数组中第K大元素-CSDN博客题的小顶堆加一个方法:
- class MinHeap {
- // ...
- public boolean isFull() {
- return size == array.length;
- }
- }
题解
- class KthLargest {
-
- private MinHeap heap;
-
- public KthLargest(int k, int[] nums) {
- heap = new MinHeap(k);
- for(int i = 0; i < nums.length; i++) {
- add(nums[i]);
- }
- }
- //add方法的作用:val是新增数据 返回值是返回第K大的元素
- public int add(int val) {
- //当初始给的数组里面是空的,此时操作就要先add添加满3个以后再执行replace操作
- if(!heap.isFull()){
- heap.offer(val);
- } else if(val > heap.peek()){
- heap.replace(val);
- }
- return heap.peek();
- }
-
- }
求数据流中的第 K 大元素,使用堆最合适不过