02、字母异位词分组:给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它们的数组下标。

1、题目描述

1.1 字母异位词分组

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

字母异位词 是由重新排列源单词的所有字母得到的一个新单词。

1.2 示例

示例 1

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

示例 2

输入: strs = [""] 
输出: [[""]]

示例 3

输入: strs = ["a"] 
输出: [["a"]]

2、解题思路

2.1 思路讲解

  • 异位词其实就是字母内容相同但是错序的单词,
  • 如果按照每个字母出现的数量或者按照字典序重排序,问题就变成了统计相同单词出现的数量

2.2 动画演示( 待补充)

2.3 复杂度分析

  • 时间复杂度 O ( n k l o g ⁡ k ) O(nk log⁡ k) O(nklogk),其中 n n n s t r s strs strs 中的字符串的数量, k k k s t r s strs strs中的字符串的的最大长度。需要遍历 n n n 个字符串,对于每个字符串,需要 O ( k l o g ⁡ k ) O(k log ⁡k) O(klogk) 的时间进行排序 O ( 1 ) O(1) O(1)的时间更新哈希表

  • 空间复杂度 O ( n k ) O(nk) O(nk),其中 n n n s t r s strs strs 中的字符串的数量, k k k s t r s strs strs 中的字符串的的最大长度。需要用哈希表存储全部字符串。

3、答案

3.1 Java 代码

public class _02_字母异位词分组 {
    public static void main(String[] args) {
        System.out.println(groupAnagrams(new String[]{"eat", "tea", "tan", "ate", "nat", "bat"}));
        System.out.println(groupAnagrams(new String[]{""}));
        System.out.println(groupAnagrams(new String[]{"a"}));
    }

    private static List<List<String>> groupAnagrams(String[] strs) {
        HashMap<String, List<String>> map = new HashMap();
        for (String str : strs) {
            char[] arr = str.toCharArray();
            Arrays.sort(arr);
            String k = new String(arr);
            List<String> list = map.getOrDefault(k, new ArrayList<>());
            list.add(str);
            map.put(k,list);
        }
        return new ArrayList<>(map.values());
    }
}

3.2 运行结果

在这里插入图片描述

4、视频讲解( 待补充)

  • 13
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Elastic开源社区

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值