You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
55 lines
1.1 KiB
55 lines
1.1 KiB
2 years ago
|
package class35;
|
||
|
|
||
|
import java.util.Comparator;
|
||
|
import java.util.HashMap;
|
||
|
import java.util.PriorityQueue;
|
||
|
|
||
|
public class Problem_0347_TopKFrequentElements {
|
||
|
|
||
|
public static class Node {
|
||
|
public int num;
|
||
|
public int count;
|
||
|
|
||
|
public Node(int k) {
|
||
|
num = k;
|
||
|
count = 1;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public static class CountComparator implements Comparator<Node> {
|
||
|
|
||
|
@Override
|
||
|
public int compare(Node o1, Node o2) {
|
||
|
return o1.count - o2.count;
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
public static int[] topKFrequent(int[] nums, int k) {
|
||
|
HashMap<Integer, Node> map = new HashMap<>();
|
||
|
for (int num : nums) {
|
||
|
if (!map.containsKey(num)) {
|
||
|
map.put(num, new Node(num));
|
||
|
} else {
|
||
|
map.get(num).count++;
|
||
|
}
|
||
|
}
|
||
|
PriorityQueue<Node> heap = new PriorityQueue<>(new CountComparator());
|
||
|
for (Node node : map.values()) {
|
||
|
if (heap.size() < k || (heap.size() == k && node.count > heap.peek().count)) {
|
||
|
heap.add(node);
|
||
|
}
|
||
|
if (heap.size() > k) {
|
||
|
heap.poll();
|
||
|
}
|
||
|
}
|
||
|
int[] ans = new int[k];
|
||
|
int index = 0;
|
||
|
while (!heap.isEmpty()) {
|
||
|
ans[index++] = heap.poll().num;
|
||
|
}
|
||
|
return ans;
|
||
|
}
|
||
|
|
||
|
}
|