leetcode 49. 字母异位词分组

49. 字母异位词分组

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

示例 1:

输入: strs = ["eat", "tea", "tan", "ate", "nat", "bat"]

输出: [["bat"],["nat","tan"],["ate","eat","tea"]]

解释:

在 strs 中没有字符串可以通过重新排列来形成 "bat"。

字符串 "nat" 和 "tan" 是字母异位词,因为它们可以重新排列以形成彼此。

字符串 "ate" ,"eat" 和 "tea" 是字母异位词,因为它们可以重新排列以形成彼此。

示例 2:

输入: strs = [""]

输出: [[""]]

示例 3:

输入: strs = ["a"]

输出: [["a"]]

题解:

这道题是把字母相同的单词放在一块,所以借助hashmap表,key是按字母排序后的单词 比如eat,key就是aet,value就是装和key字母相同的数组

java 复制代码
class Solution {
    public List<List<String>> groupAnagrams(String[] strs) {
        HashMap<String,List<String>> map=new HashMap();
        for(int i=0;i<strs.length;i++){
            char[] s=strs[i].toCharArray();
            Arrays.sort(s);
            String str=String.valueOf(s);
            if(map.get(str)==null){
                 map.put(str,new ArrayList<String>());
            }
            map.get(str).add(strs[i]);
        }
        List<List<String>> list =new ArrayList();
        for(String s:map.keySet()){
            list.add(map.get(s));
        }
        return list;

    }
}
相关推荐
GIS小天2 小时前
AI+预测3D新模型百十个定位预测+胆码预测+去和尾2025年8月25日第170弹
人工智能·算法·机器学习·彩票
PAK向日葵3 小时前
【算法导论】XM 0823 笔试题解
算法·面试
Asmalin3 小时前
【代码随想录day 21】 力扣 77. 组合
算法·leetcode·职场和发展
2501_924878598 小时前
强光干扰下漏检率↓78%!陌讯动态决策算法在智慧交通违停检测的实战优化
大数据·深度学习·算法·目标检测·视觉检测
耳总是一颗苹果9 小时前
排序---插入排序
数据结构·算法·排序算法
YLCHUP9 小时前
【联通分量】题解:P13823 「Diligent-OI R2 C」所谓伊人_连通分量_最短路_01bfs_图论_C++算法竞赛
c语言·数据结构·c++·算法·图论·广度优先·图搜索算法
花火|9 小时前
算法训练营day62 图论⑪ Floyd 算法精讲、A star算法、最短路算法总结篇
算法·图论
GuGu202410 小时前
新手刷题对内存结构与形象理解的冲突困惑
算法
汤永红10 小时前
week4-[二维数组]平面上的点
c++·算法·平面·信睡奥赛