【剑斩OFFER】算法的暴力美学——字母异位词分组

一、题目描述

二、算法原理

思路:哈希表

使用一个 unordered_map< string , vector<string>> ,这个哈希表的 key 值是以 ASCII 码值来排序归类的,value 值就是数组,专门来存储符合这个 ASCII 值排序的字符串,例如:

最后把这个哈希表的 value 值放到一个二维数组里面就行。

三、代码实现

cpp 复制代码
class Solution {
public:
    vector<vector<string>> groupAnagrams(vector<string>& strs) {
        unordered_map<string,vector<string>> hash;
        for(auto& e : strs)
        {
            string s = e;
            sort(s.begin(),s.end());//对字符进行排序
            hash[s].push_back(e);//一个 ASCII 码值来归类,刚好符合题目要求
        }

        vector<vector<string>> ret;
        for(auto& pair : hash) ret.push_back(pair.second);//把哈希表里面的值放到二维数组里面
        return ret;
    }
};
相关推荐
夏日听雨眠3 分钟前
数据结构(单循环链表)
数据结构·链表
智算菩萨6 分钟前
【How Far Are We From AGI】4 AGI的“生理系统“——从算法架构到算力基座的工程革命
论文阅读·人工智能·深度学习·算法·ai·架构·agi
福赖9 分钟前
《算法:生产车间》
算法
alphaTao17 分钟前
LeetCode 每日一题 2026/3/16-2026/3/22
linux·windows·leetcode
空空潍17 分钟前
LeetCode力扣 hot100一刷完结
算法·leetcode
leaves falling20 分钟前
搜索插入位置(第一个≥target的位置)
算法
历程里程碑21 分钟前
41 .UDP -3 群聊功能实现:线程池助力多客户端通信
linux·开发语言·网络·数据结构·c++·网络协议·udp
lcreek21 分钟前
LeetCode 1162.地图分析
算法·leetcode·bfs
寒月小酒24 分钟前
3.20 OJ
算法
AI科技星27 分钟前
基于空间光速螺旋归一化的动力学方程推导与数值验证
人工智能·线性代数·算法·机器学习·平面