【LeetCode】字母异位词分组

目录


一、题目

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

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

示例 1:

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

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

示例 2:

输入: strs = [""]

输出: [[""]]

示例 3:

输入: strs = ["a"]

输出: [["a"]]

提示:

1 <= strs.length <= 104

0 <= strs[i].length <= 100

strs[i] 仅包含小写字母


二、解法

使用哈希表

可以将每个单词,排一下序,然后相同排序的单词放到一起,最后,将每个list输出就好啦


完整代码

python 复制代码
class Solution:
    def groupAnagrams(self, strs: List[str]) -> List[List[str]]:
        dic = collections.defaultdict(list)
        for s in strs:
            dic[''.join(sorted(s))].append(s)
        return list(dic.values())

相关推荐
鱼跃鹰飞6 小时前
Leetcode面试经典150题-739.每日温度
算法·leetcode·面试
Mopes__8 小时前
Python | Leetcode Python题解之第406题根据身高重建队列
python·leetcode·题解
子非鱼92113 小时前
【JavaScript】LeetCode:36-40
开发语言·javascript·leetcode
爱吃芝麻汤圆14 小时前
633. 平方数之和-LeetCode(C++)
c++·算法·leetcode
我爱豆子15 小时前
Leetcode Hot 100刷题记录 -Day14(矩阵置0)
java·算法·leetcode·矩阵
IT规划师16 小时前
LeetCode题集-4 - 寻找两个有序数组的中位数,图文并茂,六种解法,万字讲解
leetcode·中位数
程序猿练习生16 小时前
C++速通LeetCode简单第9题-二叉树的最大深度
c++·算法·leetcode
小陶 coding17 小时前
代码随想录刷题day32丨动态规划理论基础,509. 斐波那契数, 70. 爬楼梯, 746. 使用最小花费爬楼梯
java·数据结构·算法·leetcode·动态规划
Chase-Hart18 小时前
【每日一题】LeetCode 2848.与车相交的点(数组、哈希表、前缀和)
java·数据结构·算法·leetcode·散列表
山脚ice19 小时前
【Hot100】LeetCode—84. 柱状图中最大的矩形
算法·leetcode