资讯 小学 初中 高中 语言 会计职称 学历提升 法考 计算机考试 医护考试 建工考试 教育百科
栏目分类:
子分类:
返回
空麓网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
空麓网 > 计算机考试 > 软件开发 > 后端开发 > Python

leetcode第49题python版字母异位词分组字典统计法

Python 更新时间: 发布时间: 计算机考试归档 最新发布

leetcode第49题python版字母异位词分组字典统计法

class Solution:
    """
    49. 字母异位词分组
    给你一个字符串数组,请你将 字母异位词 组合在一起。可以按任意顺序返回结果列表。
字母异位词 是由重新排列源单词的字母得到的一个新单词,所有源单词中的字母通常恰好只用一次。
anagrams 英[ˈænəgræmz] 美[ˈænəˌgræmz]n.相同字母异序词
    """
    def groupAnagrams(self, strs: List[str]) -> List[List[str]]:
        # 思路:根据特征分类的问题一般要用到hash数据结构
        # 1. 初始化及特殊处理
        if not strs:
            return []
        n = len(strs)
        if n == 1 and not strs[0]:
            return [[""]]
        group_dict = {}

        # 2. 遍历处理
        for item in strs:
            # (group_dict[sorted(item)] or group_dict[sorted(item)] = []).append(item)
            # python中字符串需要转为数组后排序, item.split()不行
            # sorted_item = ''.join(sorted(item.split()))
            sorted_item = ''.join(sorted(list(item)))
            # print(sorted_item)
            if sorted_item not in group_dict:
                group_dict[sorted_item] = []
            group_dict[sorted_item].append(item)

        # 3. 返回结果值
        # Python3 字典 values() 方法返回一个视图对象,需要通过list转为列表
        return list(group_dict.values())
转载请注明:文章转载自 http://www.konglu.com/
本文地址:http://www.konglu.com/it/916303.html
免责声明:

我们致力于保护作者版权,注重分享,被刊用文章【leetcode第49题python版字母异位词分组字典统计法】因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理,本文部分文字与图片资源来自于网络,转载此文是出于传递更多信息之目的,若有来源标注错误或侵犯了您的合法权益,请立即通知我们,情况属实,我们会第一时间予以删除,并同时向您表示歉意,谢谢!

我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2023 成都空麓科技有限公司

ICP备案号:蜀ICP备2023000828号-2