【LeetCode】49. 字母异位词分组

1 问题

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

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

示例 1:

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

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

示例 2:

输入: strs = [""]

输出: [[""]]

示例 3:

输入: strs = ["a"]

输出: [["a"]]

2 答案

这题直接不会

官方解,使用字典记录,其中字典的键,必须是不可变类型,所以用tuple。

python 复制代码
class Solution:
    def groupAnagrams(self, strs: List[str]) -> List[List[str]]:
        dict = {}
        for s in strs:
            key = tuple(sorted(s))  # 字典的键用tuple
            dict[key] = dict.get(key,[]) + [s]  # get(key,[]) get 不到则返回[]
        return list(dict.values())
相关推荐
wen__xvn7 分钟前
力扣洛谷模拟题刷题2
算法·leetcode·职场和发展
萤火阳光24 分钟前
43|Python 异步生态深度:aiohttp/aiomysql/aioredis 全链路异步实战
开发语言·网络·python
威联通安全存储32 分钟前
云原生数据湖:QuObjects 本地 S3 对象存储解析
python·云原生
chushiyunen35 分钟前
大模型评测、质量保证、datasets数据集、LmEval工具
开发语言·python
新知图书1 小时前
【图书推荐】《Python大数据分析师的算法手册》
python·数据分析
apcipot_rain1 小时前
Python 脚本生成目录树
开发语言·python
港股研究社1 小时前
广汽年报里的隐线:组织改革、生态协同与修复起点
python
Sirius.z1 小时前
第T11周:优化器对比实验
python
loriloy1 小时前
Python 环境管理工具 pyenv-win (windows版本)
windows·python·pyenv-win
William Dawson2 小时前
【Java Stream 流:高效、优雅的集合操作 ✨】
java·windows·python