題目描述#
給你一個字符串數組,請你將 字母異位詞
組合在一起。可以按任意順序返回結果列表。
字母異位詞 是由重新排列源單詞的所有字母得到的一個新單詞。
示例 1:
輸入: strs = ["eat", "tea", "tan", "ate", "nat", "bat"]
輸出: [["bat"],["nat","tan"],["ate","eat","tea"]]
示例 2:
輸入: strs = [""]
輸出: [[""]]
示例 3:
輸入: strs = ["a"]
輸出: [["a"]]
提示:
1 <= strs.length <= 10^4
0 <= strs[i].length <= 100
strs [i] 僅包含小寫字母
思路#
- 互為字母異位詞的字符串所包含的字母一定是相同的,只是順序不一致
- 那只需要定義一個 map 結構,把互為字母異位詞的字符串放到同一個 key 下面
- 而這個 key,我們可以將字符串排序或者取字符串的 charcode 值的和,或者計數字符個數的字符串都行
題解#
/**
* @param {string[]} strs
* @return {string[][]}
*/
var groupAnagrams = function(strs) {
if (strs.length === 1) return [strs];
const m = new Map();
for (let i = 0; i < strs.length; i++) {
const temp = strs[i].split('').sort().join('');
// or const temp = Array.from(strs[i]).reduce((acc, curr) => acc + curr.charCodeAt(), 0);
if (m.has(temp)) {
m.set(temp, [...m.get(temp), strs[i]]);
} else {
m.set(temp, [strs[i]]);
}
}
return Array.from(m.values());
};