哈希表-49.字母异位词分组-力扣(LeetCode)
一、题目解析
1、字母异位词:重新排列原单词所有字母可以形成彼此
2、strs[i]仅包含小写字母
二、算法原理
解法:哈希表
与其是一道算法题,这道题更像语法题
1、判断两个字符串是否是字母异位词
将字符串排序即可
2、如何分组
创建一个<string,vector<string>>的哈希表,前一个string是排列好的string,后面的vector<string>中存储的是分好的字母异位词
3、返回分组
通过创建一个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;}
};