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存储搞定。

相关推荐
i***13241 分钟前
【SpringBoot】单元测试实战演示及心得分享
spring boot·后端·单元测试
yugi9878384 分钟前
TDOA算法MATLAB实现:到达时间差定位
前端·算法·matlab
s***35308 分钟前
SpringMVC新版本踩坑[已解决]
android·前端·后端
t1987512815 分钟前
基于因子图与和积算法的MATLAB实现
开发语言·算法·matlab
le serein —f18 分钟前
用go实现-回文链表
算法·leetcode·golang
rit843249921 分钟前
MFOCUSS算法MATLAB实现:稀疏信号重构
算法·matlab·重构
发疯幼稚鬼23 分钟前
散列及其分离链接法
c语言·数据结构·算法·链表·散列表
Bdygsl23 分钟前
数字图像处理总结 Day 1
人工智能·算法·计算机视觉
北郭guo25 分钟前
垃圾回收底层原理【深入了解】
java·jvm·算法
小年糕是糕手25 分钟前
【C++同步练习】C++入门
开发语言·数据结构·c++·算法·pdf·github·排序算法