LeetCode:字母异位词分组

方法一:

java 复制代码
class Solution {
    public List<List<String>> groupAnagrams(String[] strs) {
        Map<String,List<String>> map = new HashMap<>();
        //遍历所有单词
        for(String s : strs){
            //将字符串打散成字符
            char[] chars = s.toCharArray();
            //对字符排序
            Arrays.sort(chars);
            //重新组装成字符串
            String key = new String(chars);
            //如果map中没有这个key就新建一个ArrayList放进去
            if(!map.containsKey(key)){
                map.put(key,new ArrayList<>());
            }
            //放进key对应的value中去
            map.get(key).add(s);
        }
        //返回所有值
        return new ArrayList<>(map.values());
    }
}

toCharArray():

将字符串拆成单个字符。

Arrays.sort(chars):

将字符数组排序

map.containsKey(key):

有没有key的,返回true或false

map.values():

返回map中所有的值

设有N个单词,每个单词长度为K

时间复杂度:O(N*KlogK)

空间复杂度:O(N*K)

方法二(使用字符出现的频次生成特定的key,更省时间。 ):

java 复制代码
class Solution{
    public List<List<String>> groupAnagrams(String[] strs){
        Map<String,List<String>> map = new HashMap<>();

        //循环读取数组中的每个单词
        for(String s : strs){
            int[] count = new int[26];
            //循环读取每个单词的每个字符
            for(char c : s.toCharArray()){
                //处理单个字符的出现次数
                count[c - 'a']++;
            }
            //拼接字符串
            StringBuilder sb = new StringBuilder();
            for(int i = 0;i < 26;i++){
                if(count[i] > 0){
                    sb.append((char)('a' + i));
                    sb.append(count[i]);
                }
            }
            String key = sb.toString();
            if(!map.containsKey(key)){
                map.put(key,new ArrayList<>());
            }
            map.get(key).add(s);
        }
        return new ArrayList<>(map.values());
    }
}

时间复杂度:O(N*K),没有使用排序

空间复杂度:O(N*K)

拼接字符串使用StringBuilder而不使用String,String为不可变对象,使用String拼接字符串相当于每次添加字符串都申请一个新地址,将原来的字符串抄过来再添加新的字符串,而StringBuilder则在一块连续的地址空间上进行操作,是一个字符数组,默认大小16字符,满的时候向系统申请原来容量的两倍大(通常是两倍+2)的地址空间。

相关推荐
Raink老师4 分钟前
【AI面试临阵磨枪-84】如何看待 RAG vs 微调(Fine-tuning)?选型依据
人工智能·面试·职场和发展
alphaTao15 分钟前
LeetCode 每日一题 2026/5/25-2026/5/31
算法·leetcode
菜菜的顾清寒18 分钟前
力扣HOT100(41)动态规划-杨辉三角
算法·leetcode·动态规划
Cthy_hy23 分钟前
Python算法竞赛:集合去重+字典映射 核心用法一站式整理
数据结构·python·算法
JAVA社区23 分钟前
Java高级全套教程(九)—— SpringCloud超详细实战详解
java·开发语言·后端·spring cloud·面试·职场和发展
Deepoch30 分钟前
Deepoc数学大模型:驱动发动机行业数智化转型的底层解
人工智能·算法·deepoc·数学大模型
happymaker062632 分钟前
LeetCodeHot100——盛水最多的容器
数据结构·算法·leetcode·双指针·hot100
3DVisionary33 分钟前
蓝光三维扫描:磁性轴承全尺寸精密3D检测方案
算法·3d·3d检测·蓝光三维扫描·精密检测·磁性轴承·圆度测量
学代码的真由酱38 分钟前
【自用】测开面试问题-Java
java·面试·职场和发展
过期动态39 分钟前
【LeetCode 热题 100】三数之和
java·数据结构·算法·leetcode·职场和发展·排序算法