地址:
题目
给你一个字符串数组,请你将 字母异位词 组合在一起。可以按任意顺序返回结果列表。
字母异位词 是由重新排列源单词的字母得到的一个新单词,所有源单词中的字母通常恰好只用一次。
示例
输入: strs =["eat", "tea", "tan", "ate", "nat", "bat"]输出: [["bat"],["nat","tan"],["ate","eat","tea"]]
思路
可用哈希表存储每组字母异位词,key是字母异位词标志,值为一组字母异位词列表
方法一:排序
由于互为字母异位词的两个字符串包含的字母相同,因此对两个字符串分别进行排序之后得到的字符串一定是相同的,故可以将排序之后的字符串作为哈希表的键。
代码
class Solution {
public:
    vector<vector<string>> groupAnagrams(vector<string>& strs) {
        int len = strs.size();
        if(len==0 || len==1)
            return {strs};
        unordered_map<string,vector<string>> map;
        for(string &str:strs){  //遍历每一个字符串
            string key = str;
            sort(key.begin(),key.end());    //排序
            map[key].emplace_back(str);
        }
        vector<vector<string>> res;
        for(auto it = map.begin();it!=map.end();++it){
            res.emplace_back(it->second);
        } 
        return res;
    }
}; 
复杂度分析
时间复杂度:O(nklogk),n是字符串的个数,k是字符串的长度,klogk是排序耗费的时间
空间复杂度:O(nk),用map存储全部的字符串
                  
                  
                  
                  
                            
      
          
                
                
                
                
              
                
                
                
                
                
              
                
                
              
            
                  
					291
					
被折叠的  条评论
		 为什么被折叠?
		 
		 
		
    
  
    
  
            


            