LeetCode:49. 字母异位词分组

简介

题目链接:https://leetcode.cn/problems/group-anagrams/description/

解决方式:数组 + 哈希表

这是作者学习众多大神的思路进行解题的步骤,很推荐大家解题的时候去看看题解里面大佬们的思路、想法!

哈希表

排序

思路:字母异位词,也就是字符种类与个数相同,不过排序不一样。那么我们就可以迭代数组中的每个字符串,将其按26字母表的顺序重新排序,只要是字母异位词,排序的结果就相同。我们可以将排序后的结果作为哈希表的 key,集合作为哈希表的 value。这样,字母异位词被映射到相同的 key,就可以存储进同一个分组的集合中了。

java 复制代码
class Solution {
    public List<List<String>> groupAnagrams(String[] strs) {
        // 哈希表
        Map<String,List<String>> map = new HashMap<String,List<String>>();
        // 迭代数组
        for (String str : strs){
            // 字符串转为字符数组
            char[] array = str.toCharArray();
            // 重新排序,排序结果作为字母异位词的 key
            Arrays.sort(array);
            // 转为 String
            String s = new String(array);
            // 从哈希表中拿到指定 key 的 value,没有就创建
            List<String> list = map.getOrDefault(s, new ArrayList<String>());
            list.add(str);
            // 更新 key 对应的 value
            map.put(s,list);
        }
        // 返回结果
        return new ArrayList<List<String>>(map.values());
    }
}

计数

思路:大体逻辑与上面的方法相同,都是经过观察,构建唯一的 key,通过这个 key 进行分组。只不过计数这个方法构建唯一 key 是通过统计每个字符出现的次数,然后拼接成字符串来实现的。

java 复制代码
class Solution {
    public List<List<String>> groupAnagrams(String[] strs) {
        // 哈希表
        Map<String,List<String>> map = new HashMap<String,List<String>>();
        for (String str : strs){
            int[] count = new int[26];
            int length = str.length();
            // 记录字母出现的次数
            for(int i = 0; i < length; i++){
                // 隐式含有字母排序的意思
                // 因为 count 数组索引对应的是 a-z
                count[str.charAt(i) - 'a']++;
            }
            // 构建唯一的键
            // 将每个出现次数大于 0 的字母和出现次数按顺序拼接成字符串,作为哈希表的键
            StringBuilder sb = new StringBuilder();
            for(int i = 0; i < 26; i++){
                if(count[i] != 0){
                    // 索引转为字母
                    sb.append((char)(i + 'a'));
                    sb.append(count[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());
    }
}
相关推荐
QiLinkOS10 分钟前
第三视觉理解徐玉生与他的商业活动(28)
大数据·c++·人工智能·算法·开源协议
码云数智-大飞39 分钟前
从 OC 平滑迁移 Swift 完整方案
职场和发展·蓝桥杯
wabs66644 分钟前
关于动态规划【力扣1143.最长公共子序列的思考】
算法·leetcode·动态规划
剑挑星河月1 小时前
54.螺旋矩阵
java·算法·leetcode·矩阵
Robot_Nav1 小时前
MPPI 局部规划器实验设计讲解
人工智能·算法·mppi
mingo_敏2 小时前
Mean-Teacher 均值教师自训练框架详解
算法·均值算法
水木流年追梦2 小时前
agent面试必备31- AI Agent 核心进阶:工具路由(Tool Routing)
数据库·人工智能·oracle·面试·职场和发展·embedding
星空露珠2 小时前
迷你世界UGc3.0脚本Wiki[剧情动画模块管理接口 Timeline]
开发语言·数据结构·算法·游戏·lua
笨笨没好名字2 小时前
Leetcode刷题python3版第一周(下)
linux·算法·leetcode
手写码匠3 小时前
手写 LLM 安全护栏:从内容审核到越狱防御的完整实现
人工智能·深度学习·算法·aigc