[ LeetCode ] 题刷刷(Python)-第49题:字母异位词分组

题目描述

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

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

即将含有相同字符但排列顺序不同的字符串放入同一个组中。

示例

示例 1:

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

输入: strs = [""]
输出: [[""]]
示例 3:

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

解题

解法一:排序+哈希表

思路

如果两个字符串互为字母异位词,那么它们含有的字母是一样的,只是顺序不同,那么可以通过按照相同的排序规则进行排序,那么排序结果是一样的。

然后使用排序的结果作为键,原来的字符串作为值,存放在列表里。

最后以列表的形式返回的所有值即可。

算法复杂度

时间复杂度: O(n * m * log m),其中 n 是输入列表 strs 的长度,m 是字符串的最大长度。

对于每个字符串 s,我们需要计算其字符的有序版本,即 key = ''.join(sorted(s)),sorted(s) 的时间复杂度是 O(m log m),其中 m 为字符串 s 的长度。

再加上外部有一个对输入列表 strs 的遍历,所以总的时间复杂度是 O(n * m * log m),其中 n 是输入列表 strs 的长度,m 是字符串的最大长度。


空间复杂度:O(n*m),其中 n 是输入列表 strs 的长度,m 是字符串的最大长度。

代码
class Solution:
    def groupAnagrams(self, strs: List[str]) -> List[List[str]]:
        anagram_groups = {}
        for s in strs:
            # 将字符串转换为有序的字符串作为哈希表的键
            key = ''.join(sorted(s))
            # 如果哈希表中已经有这个键,则把当前字符串加入到对应值(即组)中
            if key in anagram_groups:
                anagram_groups[key].append(s)
            else:
                anagram_groups[key] = [s]

        # 返回所有的字母异位词组
        return list(anagram_groups.values())

相关推荐

  1. [ LeetCode ] 刷刷(Python)-49字母分组

    2024-04-14 03:58:01       14 阅读
  2. leetcode49字母分组

    2024-04-14 03:58:01       24 阅读
  3. 【算法49. 字母分组

    2024-04-14 03:58:01       33 阅读
  4. LeetCode 49 字母分组

    2024-04-14 03:58:01       37 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-04-14 03:58:01       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-04-14 03:58:01       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-04-14 03:58:01       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-04-14 03:58:01       18 阅读

热门阅读

  1. 如何在Python中实现设计模式?

    2024-04-14 03:58:01       16 阅读
  2. C动\静态库编译

    2024-04-14 03:58:01       14 阅读
  3. python3面向对象

    2024-04-14 03:58:01       14 阅读
  4. pyqt写个星三角降压启动方式2

    2024-04-14 03:58:01       13 阅读
  5. postgis使用

    2024-04-14 03:58:01       16 阅读
  6. photoshop基础学习笔记

    2024-04-14 03:58:01       13 阅读
  7. 第六周学习笔记DAY.1

    2024-04-14 03:58:01       15 阅读
  8. 100个好用的安全工具推荐

    2024-04-14 03:58:01       10 阅读
  9. C++ 传值调用

    2024-04-14 03:58:01       13 阅读
  10. 有趣的小知识(五).sh文件是什么

    2024-04-14 03:58:01       13 阅读