Top K frequent words
public class Solution {
public String[] topKFrequent(String[] combo, int k) {
if (combo.length == 0) return new String[]{};
HashMap<String, Integer> count = new HashMap<String, Integer>();
//all elements into hashMap
for (String cur: combo){
count.put(cur, count.getOrDefault(cur, 0) + 1);
}
Queue<String> heap = new PriorityQueue<String>(k, new Comparator<String>(){
@Override
public int compare(String s1, String s2){
if (count.get(s1).equals(count.get(s2))) return 0;
return count.get(s2) - count.get(s1);
}
});
for (String cur: count.keySet()){ //get set of keys in HashMap
heap.offer(cur);
}
if (k > heap.size()) k = heap.size();
String[] result = new String[k];
for (int i = 0; i < result.length; i++){
result[i] = heap.poll();
}
return result;
}
}Last updated