
与其是一道算法题,这道题更像语法题
将字符串排序即可
创建一个<string,vector<string>>的哈希表,前一个string是排列好的string,后面的vector<string>中存储的是分好的字母异位词
通过创建一个vector<vector<string>> vv,用于存储分组,由于哈希表中存的是一个一个的pair, 插入second即可
class Solution {
public:
vector<vector<string>> groupAnagrams(vector<string>& strs)
{
unordered_map<string,vector<string>> hash;
for(auto str : strs)
{
string s = str;
sort(s.begin(),s.end());
hash[s].push_back(str);
}
vector<vector<string>> vv;
for(auto ha : hash)
{
vv.push_back(ha.second);
}
return vv;
}
};