LeetCode 算法题【简单】49. 字母异位词分组

语雀原文链接

1、LeetCode 链接

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

 

示例 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"]]

 

提示:

1 <= strs.length <= 104
0 <= strs[i].length <= 100
strs[i] 仅包含小写字母

2、个人写法

  • 思路:字符串排序后作为hashmap的key,List作为value,保存字母异位词
  • 时间复杂度:O(N∗Mlogm)
  1. 转换为字符数组:O(m),其中 m 是当前字符串的长度。
  2. 排序字符数组:使用 Arrays.sort() 对字符数组排序,时间复杂度为 O(m log m)。这是主导步骤。
  3. 创建键字符串:从排序后的字符数组创建新字符串,O(m)。
  4. HashMap 操作:getOrDefault 和 put 操作在平均情况下为 O(1),但键的哈希计算需要 O(m) 时间。由于排序步骤的 O(m log m) 更大,因此 HashMap 操作的时间被覆盖。
  5. 返回结果:最后将 map.values() 转换为 ArrayList,需要 O(n) 时间,但相对于 O(n * m log m) 可以忽略。
  6. 因此,总时间复杂度主要由排序步骤决定,为 O(n * m log m)。
  • 空间复杂度:O(N∗M)
plain 复制代码
class Solution {
    public List<List<String>> groupAnagrams(String[] strs) {

        int length = strs.length;

        HashMap<String, List<String>> map = new HashMap();

        for (int i = 0; i < length; i++) {
            String str = strs[i];
            char[] arr = str.toCharArray();
            Arrays.sort(arr);
            String key = new String(arr);

            List<String> list = map.getOrDefault(key, new ArrayList<String>());
            list.add(str);
            map.put(key, list);
        }

        return new ArrayList<List<String>>(map.values());

    }
}
相关推荐
朦胧之21 分钟前
AI 编程-老项目改造篇
java·前端·后端
swipe3 小时前
从 0 到 1 实现大文件上传:分片、秒传、断点续传、暂停、重试与服务端合并
前端·javascript·面试
kisshyshy5 小时前
🍦 雪糕、食堂、火车厢:三幅漫画吃透栈、队列与链表
javascript·算法
程序猿大帅5 小时前
别再只当调包侠了:用 Spring AI 落地 Function Calling,我被大模型硬生生砸出了三个大坑
java
程序员晓琪6 小时前
约定大于配置:基于 Java 包名自动生成 API 版本路由的最佳实践
java·spring boot·后端
Flittly6 小时前
【AgentScope Java新手村系列】(11)中断与恢复
java·spring boot·spring
众少成多积小致巨6 小时前
JNI (Java Native Interface) 技术手册中文参考指南
android·java·c++
东坡白菜7 小时前
破局全栈:前端开发的Java入门实战记录—JPA(2)
java·后端
阳火锅7 小时前
😭测试小姐姐终于不骂我了!这个提BUG神器太香了...
前端·javascript·面试
林希_Rachel_傻希希9 小时前
js里面的proxy理解。以及vue3响应式数据设计底层
前端·javascript·面试