题目描述
给你一个字符串数组,请你将 字母异位词 组合在一起。可以按任意顺序返回结果列表。
字母异位词 是由重新排列源单词的所有字母得到的一个新单词。
示例 1:
输入: strs = [“eat”, “tea”, “tan”, “ate”, “nat”, “bat”]
输出: [[“bat”],[“nat”,“tan”],[“ate”,“eat”,“tea”]]
示例 2:
输入: strs = [“”]
输出: [[“”]]
示例 3:
输入: strs = [“a”]
输出: [[“a”]]
提示:
1 <= strs.length <= 104
0 <= strs[i].length <= 100
strs[i] 仅包含小写字母
解法1:字符串拆分后排序,再聚合,最后再使用哈希归类。
/**
* @param {string[]} strs
* @return {string[][]}
*/
var groupAnagrams = function(strs) {
let data={}
strs.forEach((value,index,arr)=>{
let a=value.split("").sort().join("");
if(data[a]==undefined){
data[a]=[value]
}else{
data[a].push(value)
}
})
let res=[]
for(let key in data){
res.push(data[key])
}
return res
};
执行情况:
解法2:求字符串权值,按权值分类
/**
* @param {string[]} strs
* @return {string[][]}
*/
var groupAnagrams = function(strs) {
let data={}
strs.forEach((value,index,arr)=>{
let a=1;
map = {
"a":2,'b':3,'c':5,'d':7,'e':11,'f':13,'g':17,'h':19,'i':23,'j':29,'k':31,'l':37,'m':41,
'n':43,'o':47,'p':53,'q':59,'r':61,'s':67,'t':71,'u':73,'v':79,'w':83,'x':89,'y':97,'z':101
};
for(let i=0;i<value.length;i++){
a*=map[value.charAt(i)]
}
if(data[a]==undefined){
data[a]=[value]
}else{
data[a].push(value)
}
})
console.log(data)
let res=[]
for(let key in data){
res.push(data[key])
}
return res
};
执行情况
解法3:统计字符出现的次数
abbc=>a1b2c1
abcb=>a1b2c1
/**
* @param {string[]} strs
* @return {string[][]}
*/
var groupAnagrams = function(strs) {
let data={}
strs.forEach((value,index,arr)=>{
let map={}
let arr1=[]
for(let i=0;i<value.length;i++){
if(map[value.charAt(i)]==undefined){
map[value.charAt[i]]=1;
arr1.push(value.charAt(i));
}else{
map[value.charAt[i]]++;
}
}
let a=""
arr1.sort()
arr1.forEach((v,index,arr)=>{
a+=v+map[v];
})
if(data[a]==undefined){
data[a]=[value]
}else{
data[a].push(value)
}
})
console.log(data)
let res=[]
for(let key in data){
res.push(data[key])
}
return res
};
执行情况