leetcode每日一题—49.字母异位词分组

461 篇文章 1 订阅
这篇博客介绍了如何使用Python中的字典和排序技巧来将字母异位词组合在一起。通过将排序后的字符串作为字典的键,可以有效地收集相同的字母异位词,并返回它们的列表。这种方法避免了对原始列表的直接修改,而是创建了一个新的结构来存储结果。
摘要由CSDN通过智能技术生成

基础知识:
sort 与 sorted 区别:
sort() 函数用于对原列表进行排序,如果指定参数,则使用比较函数指定的比较函数。
在这里插入图片描述
sorted() 函数对所有可迭代的对象进行排序操作。
在这里插入图片描述
sort 是应用在 list 上的方法,sorted 可以对所有可迭代的对象进行排序操作。
list 的 sort 方法返回的是对已经存在的列表进行操作,而内建函数 sorted 方法返回的是一个新的 list,而不是在原来的基础上进行的操作。

题目:
给定一个字符串数组,将字母异位词组合在一起。字母异位词指字母相同,但排列不同的字符串。

在这里插入图片描述
思路:
原来还可以这样用,涨知识了在这里插入图片描述
dict.get(key, default=None)
返回指定键的值,如果键不在字典中返回 default 设置的默认值

解答:

class Solution:
    def groupAnagrams(self, strs: List[str]) -> List[List[str]]:
        dict = {}
        for item in strs:
            key = tuple(sorted(item))
            dict[key] = dict.get(key, []) + [item]
        return list(dict.values())
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值