【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;
    }
};
相关推荐
max50060022 分钟前
实时多模态电力交易决策系统:设计与实现
图像处理·人工智能·深度学习·算法·音视频
其古寺33 分钟前
贪心算法与动态规划:数学原理、实现与优化
算法·贪心算法·动态规划
rit84324991 小时前
基于灰狼算法(GWO)优化支持向量回归机(SVR)参数C和γ的实现
c语言·算法·回归
蒋士峰DBA修行之路1 小时前
实验五 静态剪枝
数据库·算法·剪枝
蒋士峰DBA修行之路1 小时前
实验六 动态剪枝
数据库·算法·剪枝
Tim_102 小时前
【算法专题训练】20、LRU 缓存
c++·算法·缓存
Lris-KK2 小时前
【Leetcode】高频SQL基础题--1341.电影评分
sql·leetcode
B612 little star king2 小时前
力扣29. 两数相除题解
java·算法·leetcode
野犬寒鸦2 小时前
力扣hot100:环形链表(快慢指针法)(141)
java·数据结构·算法·leetcode·面试·职场和发展
时光追逐者3 小时前
C# 哈希查找算法实操
算法·c#·哈希算法