【Python刷力扣hot100】49. Group Anagrams

问题

给定一个字符串数组 strs,将字母异位词组合在一起。返回的答案可以按任意顺序排列。

字母异位词(Anagram):由相同字母按照不同顺序排列组成的字符串,例如 "listen" 和 "silent"、"eat" 和 "tea" 均为字母异位词。

例1:

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

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

  • 解释:
    • There is no string in strs that can be rearranged to form "bat".
    • The strings "nat" and "tan" are anagrams as they can be rearranged to form each other.
    • The strings "ate", "eat", and "tea" are anagrams as they can be rearranged to form each other.

例2:

输入: strs = [""]

输出: [[""]]

例3:

输入: strs = ["a"]

输出: [["a"]]

约束条件:

  • 字符串数组 strs 的长度满足:1 ≤ strs.length ≤ 10⁴(即数组中至少有 1 个字符串,最多不超过 10000 个字符串)
  • 数组中每个字符串 strs[i] 的长度满足:0 ≤ strs [i].length ≤ 100(即单个字符串可能为空字符串,最长不超过 100 个字符)
  • 字符串 strs[i] 仅由小写英文字母组成(无大写字母、数字、符号等其他字符)

解:哈希表

  1. 设原始数据在list1中,可以把每个单词按字母排序,显然所有的字母异位词排序后会得到相同的单词。
  2. 把该集合存入哈希表(key:排序后的单词。value:原始单词)。但是相同的key只能有1个,所以value是一个存储了原始单词的list
  3. 遍历所有key,分别把每个key对应的value存入list2。list2就是我们要的结果

时间复杂度 O ( n k l o g k ) O(nklogk) O(nklogk): n n n是字符串数量, k k k是字符串的最大长度。需要进行 n n n次排序操作,一次排序操作的时间复杂度是 O ( k l o g k ) O(klogk) O(klogk)。

空间复杂度 O ( n k ) O(nk) O(nk):随着数组规模的增大,我们使用哈希表的空间也会等比增大,需要额外占用的空间也会增大。

python 复制代码
class Solution:
    def groupAnagrams(self, strs: List[str]) -> List[List[str]]:
        # 创建哈希表,key为排序后的字符串,value为原始字符串列表
        anagram_dict = {}
        for s in strs:
            # 对字符串按字母排序,作为哈希表的key
            sorted_str = ''.join(sorted(s))
            
            # 如果key已存在,将当前字符串添加到对应列表
            if sorted_str in anagram_dict:
                anagram_dict[sorted_str].append(s)
            # 如果key不存在,创建新的列表并添加当前字符串
            else:
                anagram_dict[sorted_str] = [s]
        # 将哈希表中的所有值(列表)组成新列表返回
        return list(anagram_dict.values())

参考

https://leetcode.cn/problems/group-anagrams

相关推荐
jinanwuhuaguo7 分钟前
OpenClaw安全使用实践全景深度指南:从“裸奔龙虾”到“可信数字堡垒”的体系化构建
开发语言·php
2501_908329857 分钟前
C++安全编程指南
开发语言·c++·算法
计算机安禾9 分钟前
【C语言程序设计】第39篇:预处理器与宏定义
c语言·开发语言·c++·vscode·算法·visual studio code·visual studio
巧妹儿10 分钟前
Python 配置管理封神技:pydantic_settings+@lru_cache,支持优先级,安全又高效,杜绝重复加载!
开发语言·python·ai·配置管理
参.商.11 分钟前
【Day43】49. 字母异位词分组
leetcode·golang
独隅14 分钟前
Python AI 全面使用指南:从数据基石到智能决策
开发语言·人工智能·python
胡耀超18 分钟前
Web Crawling 网络爬虫全景:技术体系、反爬对抗与全链路成本分析
前端·爬虫·python·网络爬虫·数据采集·逆向工程·反爬虫
m0_5698814720 分钟前
C++中的装饰器模式变体
开发语言·c++·算法
小陈的进阶之路22 分钟前
Selenium元素定位
python·selenium
李昊哲小课23 分钟前
matplotlib多子图与复杂布局实战
python·数据分析·matplotlib·数据可视化