Class KthLargest
-
- All Implemented Interfaces:
public final class KthLargest703 - Kth Largest Element in a Stream.
Easy
Design a class to find the <code>k<sup>th</sup></code> largest element in a stream. Note that it is the <code>k<sup>th</sup></code> largest element in the sorted order, not the <code>k<sup>th</sup></code> distinct element.
Implement
KthLargestclass:KthLargest(int k, int[] nums)Initializes the object with the integerkand the stream of integersnums.int add(int val)Appends the integervalto the stream and returns the element representing the <code>k<sup>th</sup></code> largest element in the stream.
Example 1:
Input
["KthLargest", "add", "add", "add", "add", "add"] [[3, [4, 5, 8, 2]], [3], [5], [10], [9], [4]]Output: null, 4, 5, 5, 8, 8
Explanation:
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 8Constraints:
<code>1 <= k <= 10<sup>4</sup></code>
<code>0 <= nums.length <= 10<sup>4</sup></code>
<code>-10<sup>4</sup><= numsi<= 10<sup>4</sup></code>
<code>-10<sup>4</sup><= val <= 10<sup>4</sup></code>
At most <code>10<sup>4</sup></code> calls will be made to
add.It is guaranteed that there will be at least
kelements in the array when you search for the <code>k<sup>th</sup></code> element.
-
-
Constructor Summary
Constructors Constructor Description KthLargest(Integer maxSize, IntArray nums)
-