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

一、题目解析

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

2、strs[i]仅包含小写字母

二、算法原理

解法:哈希表

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

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;
    }
};

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

相关推荐
java修仙传6 分钟前
力扣hot100:寻找旋转排序数组中的最小值
算法·leetcode·职场和发展
胖咕噜的稞达鸭11 分钟前
算法日记专题:位运算II( 只出现一次的数字I II III 面试题:消失的两个数字 比特位计数)
c++·算法·动态规划
茉莉玫瑰花茶13 分钟前
ProtoBuf - 3
服务器·c++·protobuf
Algebraaaaa22 分钟前
为什么线程阻塞要用.join而不是.wait
java·c++·python
墨雪不会编程32 分钟前
C++内存管理深度剖析
java·开发语言·c++
万法若空1 小时前
【wxWidgets教程】控件基础知识
c++·gui·wxwidgets·事件处理
图形学爱好者_Wu1 小时前
每日一个C++知识点|模板
c++
xiaolang_8616_wjl1 小时前
c++超级细致的基本框架
开发语言·数据结构·c++·算法
Joy-鬼魅2 小时前
Win10x64系统VS2022使用CreateFileMapping返回无效句柄
c++·createfilemap·vc·getlasterror
冷崖2 小时前
排序--基数排序
c++·算法