49. 字母异位词分组
给定一个字符串数组,将字母异位词组合在一起。字母异位词指字母相同,但排列不同的字符串。
思路
对每个字符串进行排序,记入哈希表里面,遍历哈希表取出结果即可。
代码
class Solution {
public:
vector<vector<string>> groupAnagrams(vector<string>& strs) {
unordered_map<string, vector<string>> m;
for(int i = 0; i < strs.size(); i++) {
string key = strs[i];
sort(key.begin(), key.end());
m[key].emplace_back(strs[i]);
}
vector<vector<string>> ans;
for(auto& iter : m) {
ans.emplace_back(iter.second);
}
return ans;
}
};