力扣100题---字母异位词分组

1.字母异位词分组

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

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

方法一:字母排序



java 复制代码
class Solution {
    public List<List<String>> groupAnagrams(String[] strs) {
        // 处理边界情况:如果输入数组为空,直接返回空列表
        if (strs.length == 0) return new ArrayList<>();
        
        // 创建哈希表:键为排序后的字符数组(字符串形式),值为该异位词组对应的字符串列表
        Map<String, List<String>> map = new HashMap<>();
        
        // 遍历输入的每个字符串
        for (String str : strs) {
            // 将字符串转换为字符数组,以便进行排序
            char[] chars = str.toCharArray();
            
            // 对字符数组进行排序(例如:"eat" → ['a', 'e', 't'])
            // 排序后相同异位词的字符数组顺序相同,可作为相同的键
            Arrays.sort(chars);
            
            // 将排序后的字符数组转换为字符串,作为哈希表的键
            // 例如:['a', 'e', 't'] → "aet"
            String key = String.valueOf(chars);
            
            // 检查哈希表中是否已存在该键
            // 如果不存在,创建一个新的空列表,并与该键关联
            if (!map.containsKey(key)) {
                map.put(key, new ArrayList<>());
            }
            
            // 将原始字符串添加到对应键的列表中
            // 例如:"eat" 和 "tea" 都会被添加到键 "aet" 对应的列表中
            map.get(key).add(str);
        }
        
        // 将哈希表中的所有值(列表集合)转换为一个大列表并返回
        // 每个子列表包含一组互为异位词的字符串
        return new ArrayList<>(map.values());
    }
}

方法二 字符计数法

时间复杂度和空间复杂度


java 复制代码
class Solution {
    public List<List<String>> groupAnagrams(String[] strs) {
        // 创建一个哈希表,用于分组异位词
        // 键:由字母和出现次数组成的字符串(如 "a1b2")
        // 值:所有符合该模式的字符串列表(如 ["abb", "bab", "bba"])
       Map<String , List<String>> map =new HashMap<>();

        // 遍历输入的每个字符串
        for(String str : strs){ // 创建一个长度为26的数组,统计每个字母的出现次数
            // counts[0] 对应 'a' 的次数,counts[1] 对应 'b' 的次数,依此类推
            int[] counts =new int[26]; 
            int length =str.length();
            
            // 遍历字符串中的每个字符,统计次数
                for(int i=0;i<length;i++){
            // 将字符转换为数组索引:'a' 变成 0,'b' 变成 1,...,'z' 变成 25
                // 对应位置的计数加1
            counts[str.charAt(i)- 'a' ] ++;

                }

            StringBuilder sb = new StringBuilder();
            // 生成用于哈希表的键
            // 按字母顺序拼接每个出现过的字母及其次数(如 "a1b2")
             for(int i= 0 ; i < 26 ; i++ ){
                if(counts[i]!= 0){
                    // 添加字母(如 'a')
                    sb.append((char)('a'+i));
                      // 添加该字母的出现次数(如 2)
                    sb.append(counts[i]);
                }
             }

             String key = sb.toString();
            
            // 将当前字符串添加到对应的分组中
            // 如果键不存在,创建一个新的列表
            // 如果键已存在,获取已有的列表

            List<String> list=map.getOrDefault(key,new ArrayList<>());
            list.add(str);
            map.put(key,list);
            }
           
            // 返回哈希表中所有的值(即所有分组)
            return new ArrayList<>(map.values());
        }
  
}
相关推荐
程序员泠零澪回家种桔子几秒前
OpenManus开源自主规划智能体解析
人工智能·后端·算法
请注意这个女生叫小美3 分钟前
C语言 实例20 25
c语言·开发语言·算法
好学且牛逼的马4 分钟前
【Hot100|22-LeetCode 206. 反转链表 - 完整解法详解】
算法·leetcode·矩阵
hans汉斯6 分钟前
国产生成式人工智能解决物理问题能力研究——以“智谱AI”、“讯飞星火认知大模型”、“天工”、“360智脑”、“文心一言”为例
大数据·人工智能·算法·aigc·文心一言·汉斯出版社·天工
v_for_van10 分钟前
力扣刷题记录3(无算法背景,纯C语言)
c语言·算法·leetcode
ValhallaCoder13 分钟前
hot100-矩阵
数据结构·python·算法·矩阵
散峰而望14 分钟前
【基础算法】穷举的艺术:在可能性森林中寻找答案
开发语言·数据结构·c++·算法·随机森林·github·动态规划
心.c16 分钟前
Vue3+Node.js实现文件上传分片上传和断点续传【详细教程】
前端·javascript·vue.js·算法·node.js·哈希算法
散峰而望16 分钟前
【基础算法】算法的“预谋”:前缀和如何改变游戏规则
开发语言·数据结构·c++·算法·github·动态规划·推荐算法
We་ct17 分钟前
LeetCode 48. 旋转图像:原地旋转最优解法
前端·算法·leetcode·typescript