LeetCode题解692. 前K个高频单词

给一非空的单词列表,返回前 k 个出现次数最多的单词。

返回的答案应该按单词出现频率由高到低排序。如果不同的单词有相同出现频率,按字母顺序排序。

示例 1:

输入: ["i", "love", "leetcode", "i", "love", "coding"], k = 2

输出: ["i", "love"]

解析: "i" 和 "love" 为出现次数最多的两个单词,均为2次。

注意,按字母顺序 "i" 在 "love" 之前。

 

示例 2:

输入: ["the", "day", "is", "sunny", "the", "the", "the", "sunny", "is", "is"], k = 4

输出: ["the", "is", "sunny", "day"]

解析: "the", "is", "sunny" 和 "day" 是出现次数最多的四个单词,

出现次数依次为 4, 3, 2 和 1 次。

 

注意:

假定 k 总为有效值, 1 ≤ k ≤ 集合元素数。

输入的单词均由小写字母组成。

 

扩展练习:

尝试以 O(n log k) 时间复杂度和 O(n) 空间复杂度解决。

来源:力扣(LeetCode)

链接:https://leetcode-cn.com/problems/top-k-frequent-words

著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

题解:领取
js解法
LeetCode题解692. 前K个高频单词
```javascript
var topKFrequent = function(words, k) {
let map = new Map(),
result = [];

words.forEach((item) => {
let num = map.get( item );
if (num === undefined) {
map.set( item, 1 );
}
else {
map.set( item, num + 1 )
}
})

map = Array.from( map );

map.sort((a, b) => {
return b[1] - a[1];
});

let start = 0, val = null;
for (let i = 0; i < map.length; i++) {
if (val === null) {
val = map[i][1];
}
else {
if (map[i][1] !== val) {
// 拿出去排序,拿回来拼接
let section = map.slice(start, i);
section.sort( (a, b) => {
return a[0] > b[0] ? 1 : -1;
});
map.splice(start, i - start, ...section);
// 初始化 start val
start = i;
val = map[i][1];
}
}
}

if (start !== null) {
let section = map.slice(start, map.length);
section.sort( (a, b) => {
return a[0] > b[0] ? 1 : -1;
});
map.splice(start, map.length - start, ...section);
}

for (let i = 0; i < k; i++) {
if (map[i]) {
result.push( map[i][0] );
}
}

return result;
};
```

LeetCode题解计算机为什么是基于二进制的?

可以是三进制么?二进制有什么好处?题解:为什么叫电子计算机?算盘应该没有二进制

LeetCode题解深度优先遍历和回溯的关系?

深度优先遍历的范围更大还是回溯的范围更大?为什么?题解:我的理解是:dfs是回溯思想的一种体现- 回溯:是在整个搜索空间中搜索出可行解,在搜索过程中不断剪枝回退,这是回溯的思想,这个搜索空间并没有限制于特定的数据结构。- dfs:dfs是指特定的数据结构中如图,树(特殊的图)中搜索答案,范围限制在了特定的数据结构。个人拙见。

LeetCode题解盲人买袜子。

他们都各自买了两对黑袜和两对白袜,八对袜子的布质、大小完全相同,而每对袜子都有一张商标纸连着。两位盲人不小心将八对袜子混在一起。他们每人怎样才能取回黑袜和白袜各两对呢?题解:暴力破解, 把袜子都拆开 一人一只 哈哈

LeetCode题解10个小球,随机分到12个盒子里,求恰好10个盒子都为空的概率。

10个小球,随机分到12个盒子里,求恰好10个盒子都为空的概率。要求用程序模拟十万次,暴力求出该概率来自:字节跳动 算法工程师一面的第一题 (3月30日,60分钟,牛客网视频面)https://www.nowcoder.com/discuss/395924

LeetCode题解微信红包

微信红包 如何分配 让每个人在数学期望上是一样的?在概率论和统计学中,数学期望(mean)(或均值,亦简称期望)是试验中每次可能结果的概率乘以其结果的总和,是最基本的数学特征之一。 它反映随机变量平均取值的大小。 需要注意的是,期望值并不一定等同于常识中的“期望”——“期望值”也许与每一个结果都不相等。 期望值是该变量输出值的平均数。