【LeetCode热题100】【哈希】字母异位词分组

给你一个字符串数组,请你将 字母异位词 组合在一起。可以按任意顺序返回结果列表。

字母异位词 是由重新排列源单词的所有字母得到的一个新单词。

示例 1:

复制代码
输入: strs = ["eat", "tea", "tan", "ate", "nat", "bat"]
输出: [["bat"],["nat","tan"],["ate","eat","tea"]]

示例 2:

复制代码
输入: strs = [""]
输出: [[""]]

示例 3:

复制代码
输入: strs = ["a"]
输出: [["a"]]

提示:

  • 1 <= strs.length <= 104
  • 0 <= strs[i].length <= 100
  • strs[i] 仅包含小写字母

题解

题目的意思是将这些单词分类,由相同字母组成的单词分为一类

可以想到的是将所有单词重新排序,相同的划分为一类

用哈希映射,重新排序的单词作为key,value为原本单词的类,用容器来装这一个类的单词

C++实现

复制代码
class Solution {
public:
    vector<vector<string>> groupAnagrams(vector<string>& strs) {
        unordered_map<string,vector<string>>hash;
        for(auto&word:strs){
            string key=word;
            sort(key.begin(),key.end());
            hash[key].push_back(word);
        }
        vector<vector<string>>answer;
        for(auto it=hash.begin();it!=hash.end();it++){
            answer.push_back(it->second);
        }
        return answer;
    }
};
相关推荐
dazzle几秒前
Python数据结构(十):冒泡排序详解
数据结构·python·算法
平生不喜凡桃李6 分钟前
LeetCode:二叉树的最近公共祖先
算法·leetcode·职场和发展
czhaii10 分钟前
math.h数学函数库 ctype.h函数
c语言·c++·算法·机器学习
好学且牛逼的马20 分钟前
【Hot100|17-LeetCode 73. 矩阵置零 - 完整解法详解】
算法·leetcode·职场和发展
进击的小头25 分钟前
IIR滤波器核心原理深化:从差分方程到工业级实现
c语言·python·算法
AllData公司负责人35 分钟前
【亲测好用】数仓建模平台能力演示
大数据·数据库·算法
爱学习的阿磊37 分钟前
自定义操作符重载指南
开发语言·c++·算法
zhuanggoahead1 小时前
拓扑排序(Kahn算法)
网络·数据结构·c++·算法·排序算法
码农水水1 小时前
SpringBoot配置优化:Tomcat+数据库+缓存+日志全场景教程
java·数据库·spring boot·后端·算法·tomcat·哈希算法
JMchen1231 小时前
Android音频处理全解析:从3A算法到空间音频,打造专业级音频体验
android·经验分享·算法·kotlin·android studio·音视频