Given an array of strings words
and an integer k
, return the k
most frequent strings.
Return the answer sorted by the frequency from highest to lowest. Sort the words with the same frequency by their lexicographical order.
Example 1:
Input: words = ["i","love","leetcode","i","love","coding"]
and k = 2
Output: ["i","love"]
Example 2:
Input: words = ["the","day","is","sunny","the","the","the","sunny","is","is"]
and k = 4
Output: ["the","is","sunny","day"]
def topKFrequent(self, words, k):
count = collections.Counter(words)
heap = [(-freq, word) for word, freq in count.items()]
heapq.heapify(heap)
return [heapq.heappop(heap)[1] for _ in range(k)]