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

相关推荐
计算机毕设VX:Fegn089513 分钟前
计算机毕业设计|基于springboot + vue图书借阅管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
疯狂的程序猴19 分钟前
IPA 深度混淆是什么意思?分析其与普通混淆的区别
后端
仰泳的熊猫20 分钟前
1077 Kuchiguse
数据结构·c++·算法·pat考试
cci22 分钟前
Remote ssh无法连接?
后端
JohnYan32 分钟前
Bun技术评估 - 22 Stream
javascript·后端·bun
林希_Rachel_傻希希41 分钟前
手写Promise最终版本
前端·javascript·面试
LYFlied43 分钟前
【每日算法】LeetCode 19. 删除链表的倒数第 N 个结点
算法·leetcode·链表
okseekw44 分钟前
Maven从入门到实战:核心概念+配置详解+避坑指南
java·后端
该用户已不存在1 小时前
Node.js后端开发必不可少的7个核心库
javascript·后端·node.js
踏浪无痕1 小时前
计算机算钱为什么会算错?怎么解决?
后端·算法·面试