LeetCode 49. 字母异位词分组

49. 字母异位词分组

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

字母异位词 是由重新排列源单词的所有字母得到的一个新单词。

示例 1:

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

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

示例 2:

输入: strs = ""

输出:\[""]

示例 3:

**输入:**strs = "a"

输出: \["a"]

提示:

  • 1 <= strs.length <= 10^4
  • 0 <= strsi.length <= 100
  • strsi 仅包含小写字母

解法思路:

1、排序

2、计数

法一:

java 复制代码
class Solution {
    public List<List<String>> groupAnagrams(String[] strs) {
        // 排序, n 是 strs 中字符串数量,k 是 strs 中字符串最大长度
        // Time: O(nklogk)
        // Space: O(nk)
        Map<String, List<String>> map = new HashMap<String, List<String>>();
        for (String str : strs) {
            char[] chs = str.toCharArray();
            Arrays.sort(chs);
            String key = new String(chs);
            List<String> list = map.getOrDefault(key, new ArrayList<String>());
            list.add(str);
            map.put(key, list);
        }
        return new ArrayList<List<String>>(map.values());
    }
}

法二:

java 复制代码
class Solution {
    public List<List<String>> groupAnagrams(String[] strs) {
        // 计数, n = strs.length,k = Max(str.length()), ∣Σ∣ = 26
        // Time: O(n(k+∣Σ∣))
        // Space: O(n(k+∣Σ∣))
        Map<String, List<String>> map = new HashMap<String, List<String>>();
        for (String str : strs) {
            int[] counts = new int[26];
            int len = str.length();
            for (int i = 0; i < len; i++) {
                counts[str.charAt(i) - 'a']++;
            }
            StringBuffer sb = new StringBuffer();
            for (int i = 0; i < 26; i++) {
                if (counts[i] != 0) {
                    sb.append((char) ('a' + i));
                    sb.append(counts[i]);
                }
            }
            String key = sb.toString();
            List<String> list = map.getOrDefault(key, new ArrayList<String>());
            list.add(str);
            map.put(key, list);
        }
        return new ArrayList<List<String>>(map.values());
    }
}
相关推荐
起个破名想半天了1 天前
算法与数据结构之Dijkstra算法
数据结构·dijkstra·单源最短路径·迪杰斯特拉算法
团象科技1 天前
走访近百支出海技术团队后的海外云计算资源选型实操观察
大数据·人工智能·算法
小锋java12341 天前
【技术专题】LangChain4j 开发Java Agent智能体 - 嵌入模型与向量数据库
java·人工智能
程序员皮皮林1 天前
Dubbo 的 SPI 和 JDK 的 SPI 有什么区别?
java·开发语言·dubbo
啦啦啦啦啦zzzz1 天前
数据结构:哈夫曼编码
数据结构·c++·哈夫曼编码
小锋java12341 天前
10分钟学会Java16新特性record
java
是多巴胺不是尼古丁1 天前
java‘期末复习--多态
java·开发语言
瑞雪兆丰年兮1 天前
[从0开始学Java|第二十五天]项目阶段(综合练习&斗地主小游戏)
java·windows
勤自省1 天前
吴恩达机器学习课程实验:线性回归模型入门(课后实验)
人工智能·算法·机器学习·回归·线性回归
ChillCoding1 天前
更新中:C++ STL库,查找排序(基础算法),数据结构,数学算法,竞赛相关基础
数据结构·c++·算法