LeetCode第49题字母异位词分组

继续打卡算法题,今天学习的是LeetCode第49题字母异位词分组,这道题目是道中等题。算法题的一些解题思路和技巧真的非常巧妙,每天看一看算法题和解题思路,我相信对我们的编码思维和编码能力有一些提升。

分析一波题目

本题首先要理解 字母异位词 ,就是由相同的字母,组成的字符串

本题需要对 字母异位词 分组,我们可以使用map来实现。

编码解决

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();
            //排序,利于比较是否字母异位词
            Arrays.sort(array);
            String key = new String(array);
            List<String> list = map.getOrDefault(key, new ArrayList<String>());
            list.add(str);
            map.put(key, list);
        }
        return new ArrayList<List<String>>(map.values());

    }
}

总结

本题还是比较容易的,排序之后,使用hashmap存储搞定。

相关推荐
Hcoco_me2 分钟前
大模型面试题14:K-means聚类算法全解析(通用场景+深度拓展)
算法·kmeans·聚类
qwepoilkjasd8 分钟前
std::string详解
后端
bcbnb9 分钟前
iOS 应用上架流程的工程化拆解 从签名体系到提交审核的全过程管控
后端
数新网络10 分钟前
Compaction in Apache Iceberg
后端
神奇的程序员13 分钟前
实现一个内网服务监测告警系统
后端·自动化运维
马卡巴卡14 分钟前
Spring监听器(ApplicationEvent):比MQ更轻的异步神器!
后端
Jay200211114 分钟前
【机器学习】30 基于内容的过滤算法
人工智能·算法·机器学习
QZQ5418816 分钟前
go中单例模式以及使用反射破坏单例的方法
后端
冰西瓜60017 分钟前
分治(二)算法设计与分析 国科大
数据结构·算法
bcbnb20 分钟前
iOS 反编译防护工具全景解析 从底层符号到资源层的多维安全体系
后端