哈希表-49.字母异位词分组-力扣(LeetCode)

一、题目解析

1、字母异位词:重新排列原单词所有字母可以形成彼此

2、strsi仅包含小写字母

二、算法原理

解法:哈希表

与其是一道算法题,这道题更像语法题

1、判断两个字符串是否是字母异位词

将字符串排序即可

2、如何分组

创建一个<string,vector<string>>的哈希表,前一个string是排列好的string,后面的vector<string>中存储的是分好的字母异位词

3、返回分组

通过创建一个vector<vector<string>> vv,用于存储分组,由于哈希表中存的是一个一个的pair, 插入second即可

三、代码示例

cpp 复制代码
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;
    }
};

看到最后,如果对您有所帮助,还请点赞、收藏和关注一键三连,感谢您的观看,我们下期再见!

相关推荐
apocelipes1 天前
常用编程语言和库的正则表达式性能对比
c语言·c++·python·性能优化·golang·开发工具和环境
郝学胜_神的一滴2 天前
CMake 034:生成器表达式:解耦构建时序、精简分支逻辑的终极利器
c++·cmake
见过夏天3 天前
C++ 基础入门完全指南
c++
用户805533698034 天前
不止三件套:QObject 属性系统全关键字与运行时反射!
c++·qt
To_OC5 天前
LC 207 课程表:刚学图论那会儿,我连这是拓扑排序都没看出来
javascript·算法·leetcode
To_OC5 天前
LC 208 实现 Trie 前缀树:曾被名字劝退,写完发现是送分题
javascript·算法·leetcode
BadBadBad__AK5 天前
线段树维护区间 k 次方和
c++·数学·算法·stl
卷无止境5 天前
Eigen 库如何借助 OpenMP 加速计算
c++·后端
卷无止境5 天前
OpenMPI、MPICH 与 OpenMP:关系、核心概念与架构全解
c++·后端
To_OC6 天前
LC 994 腐烂的橘子:人人都说是 BFS 入门题,我却写了三遍才过
javascript·算法·leetcode