字母异位词分组(哈希表+排序)
给你一个字符串数组,请你将 字母异位词 组合在一起。可以按任意顺序返回结果列表。
字母异位词 是由重新排列源单词的所有字母得到的一个新单词。
示例 1:
输入: strs = ["eat", "tea", "tan", "ate", "nat", "bat"]
输出: [["bat"],["nat","tan"],["ate","eat","tea"]]
示例 2:
输入: strs = [""]
输出: [[""]]
示例 3:
输入: strs =["a"]输出: [["a"]]
思路:使用哈希表,对每个字符串使用sort进行排序。
class Solution { public: vector<vector<string>> groupAnagrams(vector<string>& strs) { int n = strs.size(); map<string,vector<string>> mp; for(int i=0;i<n;i++){ string key = strs[i]; sort(key.begin(),key.end()); mp[key].emplace_back(strs[i]); } vector<vector<string>> res; for(auto it = mp.begin();it!=mp.end();it++){ res.push_back(it->second); } return res; } };
浙公网安备 33010602011771号