49.字母异位词分组

给你一个字符串数组,请你将 字母异位词 组合在一起。可以按任意顺序返回结果列表。

示例 1:

输入: strs = "eat", "tea", "tan", "ate", "nat", "bat"

输出:\["bat","nat","tan","ate","eat","tea"]

解释:

  • 在 strs 中没有字符串可以通过重新排列来形成 "bat"
  • 字符串 "nat""tan" 是字母异位词,因为它们可以重新排列以形成彼此。
  • 字符串 "ate""eat""tea" 是字母异位词,因为它们可以重新排列以形成彼此。

示例 2:

输入: strs = ""

输出:\[""]

示例 3:

输入: strs = "a"

输出:\["a"]


思路:

题目要将字母异位词 组合在一起说明字母异位词 一定有他们的共性

  • 字母异位词的每个词组的异位词经过ASCLL码排序后一定是一样的词组
  • 字母异位词的每个字母出现的次数是一样的

按照第一种共性我们就可以遍历每个字母异位词,先经过排序(作为key),然后将相同的key的字母异位词放入同一个集合即可

复制代码
class Solution {
    public List<List<String>> groupAnagrams(String[] strs) {
       HashMap<String, List<String>> hashMap = new HashMap<>();
        for (String str : strs) {
            char[] charArray = str.toCharArray();
            Arrays.sort(charArray);
            String key = new String(charArray);
            if (!hashMap.containsKey(key)) {
                ArrayList<String> strings = new ArrayList<>();
                strings.add(str);
                hashMap.put(key, strings);
            } else {
                List<String> strings = hashMap.get(key);
                strings.add(str);
                hashMap.put(key, strings);
            }
        }
        return new ArrayList<>(hashMap.values());
    }
} 

相关推荐
青石路1 小时前
记一次多JDK版本问题的排查,一坑套一坑,差点没爬上来
java
像我这样帅的人丶你还4 小时前
Java 后端详解(五):Redis 缓存
java·后端·全栈
plainGeekDev6 小时前
GreenDAO → Room
android·java·kotlin
亦暖筑序11 小时前
Java 8老系统AI Workflow实战:把一次性AI对话升级成可恢复工作流
java·后端
敲代码的彭于晏12 小时前
Bean 生命周期完全图解:前端同学也能看懂的 Spring 核心机制
java·前端·后端
plainGeekDev13 小时前
ButterKnife → ViewBinding
android·java·kotlin
像我这样帅的人丶你还1 天前
Java 后端详解(四):分页与搜索
java·javascript·后端
她的男孩1 天前
数据权限为什么不能只靠注解?Forge 的 Mapper 层 SQL 改写源码拆解
java·后端·架构
tntxia1 天前
Mybatis的日志输入
java
亦暖筑序1 天前
Java 8老系统Browser Agent实战:三层拦截把AI操作后台变成可审计流程
java·后端·设计模式