码迷,mamicode.com
首页 > 其他好文 > 详细

471. 最高频的K个单词

时间:2020-06-17 01:51:03      阅读:68      评论:0      收藏:0      [点我收藏+]

标签:inpu   col   mat   button   div   词典   elf   bar   array   

471. 最高频的K个单词

中文English

给一个单词列表,求出这个列表中出现频次最高的K个单词。

样例

样例 1:

输入:
  [
    "yes", "lint", "code",
    "yes", "code", "baby",
    "you", "baby", "chrome",
    "safari", "lint", "code",
    "body", "lint", "code"
  ]
  k = 3
输出: ["code", "lint", "baby"]

样例 2:

输入:
  [
    "yes", "lint", "code",
    "yes", "code", "baby",
    "you", "baby", "chrome",
    "safari", "lint", "code",
    "body", "lint", "code"
  ]
  k = 4
输出: ["code", "lint", "baby", "yes"] 

挑战

用 O(n log k)的时间和 O(n) 的额外空间完成。

注意事项

你需要按照单词的词频排序后输出,越高频的词排在越前面。如果两个单词出现的次数相同,则词典序小的排在前面。

 
 
输入测试数据 (每行一个参数)如何理解测试数据?
class Solution:
    """
    @param words: an array of string
    @param k: An integer
    @return: an array of string
    """
    """
    大致思路:
    1.初始化dic,求得所有单词出现的次数,然后根据词典序进行排列,最后返回前K个即可
    """
    def topKFrequentWords(self, words, k):
        # write your code here
        #初始化
        dic = {}
        sort_list = []
        res = []
        
     #首先先根据词典序排好序,逆序 words
= sorted(words)[:: -1] for word in words: dic[word] = dic.get(word, 0) + 1for key,value in dic.items(): sort_list.append([key, value]) sort_list = sorted(sort_list, key = lambda A: A[1])[:: -1] return [_[0] for _ in sort_list[: k]]

 

471. 最高频的K个单词

标签:inpu   col   mat   button   div   词典   elf   bar   array   

原文地址:https://www.cnblogs.com/yunxintryyoubest/p/13149977.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!