力扣hot 100:49. 字母异位词分组(python C++)

目录

  • 题目描述:
    • 题解(python):(方法一:排序)
      • 代码解析
      • 代码运行解析
    • 题解(C++):(方法一:排序)
      • 代码解析&运行解析

原题目链接

题目描述:

示例 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] 仅包含小写字母

题解(python):(方法一:排序)

class Solution:def groupAnagrams(self, strs: List[str]) -> List[List[str]]:mp = collections.defaultdict(list)for st in strs:key = "".join(sorted(st))mp[key].append(st)return list(mp.values())

代码解析

这段代码定义了一个名为 Solution 的类,类中包含一个名为 groupAnagrams 的方法。该方法用于将一组字符串按字母异位词(anagram)分组。以下是代码的逐行解析:

class Solution:def groupAnagrams(self, strs: List[str]) -> List[List[str]]:
  • 这段代码定义了一个类 Solution,类中包含一个方法 groupAnagrams。这个方法接收一个参数 strs,它是一个字符串列表(List[str]),返回值是一个列表,列表中的每个元素也是一个字符串列表(List[List[str]])。
        mp = collections.defaultdict(list)
  • 这里定义了一个名为 mp 的变量,它是一个 defaultdict(来自 collections 模块)。defaultdict 是一种字典,它在引用的键不存在时会自动创建键,并将其值初始化为指定的默认值。在这个例子中,默认值是一个空列表。
        for st in strs:key = "".join(sorted(st))mp[key].append(st)
  • 这一段代码遍历输入的字符串列表 strs
    • 对于每个字符串 st,通过 sorted(st) 对字符串的字符进行排序,得到一个排序后的字符列表。
    • 然后通过 ''.join(sorted(st)) 将排序后的字符列表重新组合成一个字符串 key
    • 使用这个 key 作为键,将原始字符串 st 添加到 mp 字典中对应的列表中。
        return list(mp.values())
  • 最后,将字典 mp 中所有的值(即各个字母异位词分组的列表)转换为一个列表,并返回这个列表。

总结:

  • 这个方法的主要作用是将输入的字符串列表按字母异位词分组。字母异位词是指由相同字母组成但顺序不同的字符串。
  • 通过对每个字符串的字符进行排序,可以生成唯一的键(排序后的字符串),用这个键来将原始字符串分组。

例如,输入 ["eat", "tea", "tan", "ate", "nat", "bat"],该方法将返回 [['eat', 'tea', 'ate'], ['tan', 'nat'], ['bat']]

代码运行解析

当然可以!我们来详细跟踪代码执行的每一步,以理解它是如何处理输入 ["eat", "tea", "tan", "ate", "nat", "bat"] 的。

import collectionsclass Solution:def groupAnagrams(self, strs: List[str]) -> List[List[str]]:mp = collections.defaultdict(list)
  • 创建了一个 defaultdict,初始状态 mp 是空的:mp = {}
        for st in strs:key = "".join(sorted(st))mp[key].append(st)

遍历 strs 列表,并对每个字符串执行以下操作:

  1. 处理 st = "eat":

    • sorted("eat") 结果是 ['a', 'e', 't']
    • key = "".join(['a', 'e', 't']) 结果是 "aet"
    • mp["aet"].append("eat"),更新后的 mp 是:{'aet': ['eat']}
  2. 处理 st = "tea":

    • sorted("tea") 结果是 ['a', 'e', 't']
    • key = "".join(['a', 'e', 't']) 结果是 "aet"
    • mp["aet"].append("tea"),更新后的 mp 是:{'aet': ['eat', 'tea']}
  3. 处理 st = "tan":

    • sorted("tan") 结果是 ['a', 'n', 't']
    • key = "".join(['a', 'n', 't']) 结果是 "ant"
    • mp["ant"].append("tan"),更新后的 mp 是:{'aet': ['eat', 'tea'], 'ant': ['tan']}
  4. 处理 st = "ate":

    • sorted("ate") 结果是 ['a', 'e', 't']
    • key = "".join(['a', 'e', 't']) 结果是 "aet"
    • mp["aet"].append("ate"),更新后的 mp 是:{'aet': ['eat', 'tea', 'ate'], 'ant': ['tan']}
  5. 处理 st = "nat":

    • sorted("nat") 结果是 ['a', 'n', 't']
    • key = "".join(['a', 'n', 't']) 结果是 "ant"
    • mp["ant"].append("nat"),更新后的 mp 是:{'aet': ['eat', 'tea', 'ate'], 'ant': ['tan', 'nat']}
  6. 处理 st = "bat":

    • sorted("bat") 结果是 ['a', 'b', 't']
    • key = "".join(['a', 'b', 't']) 结果是 "abt"
    • mp["abt"].append("bat"),更新后的 mp 是:{'aet': ['eat', 'tea', 'ate'], 'ant': ['tan', 'nat'], 'abt': ['bat']}
        return list(mp.values())
  • 最终,将 mp 的值转换为列表:list(mp.values())
  • 返回结果是 [['eat', 'tea', 'ate'], ['tan', 'nat'], ['bat']]

综上,代码的每一步执行结果如下:

  1. mp = {} (初始状态)
  2. mp = {'aet': ['eat']}
  3. mp = {'aet': ['eat', 'tea']}
  4. mp = {'aet': ['eat', 'tea'], 'ant': ['tan']}
  5. mp = {'aet': ['eat', 'tea', 'ate'], 'ant': ['tan']}
  6. mp = {'aet': ['eat', 'tea', 'ate'], 'ant': ['tan', 'nat']}
  7. mp = {'aet': ['eat', 'tea', 'ate'], 'ant': ['tan', 'nat'], 'abt': ['bat']}
  8. 返回值:[['eat', 'tea', 'ate'], ['tan', 'nat'], ['bat']]

题解(C++):(方法一:排序)

class Solution {
public:vector<vector<string>> groupAnagrams(vector<string>& strs) {unordered_map<string, vector<string>> mp;for (string& str:strs){string key = str;sort(key.begin(),key.end());mp[key].emplace_back(str);}vector<vector<string>> ans;for (auto it = mp.begin();it != mp.end(); ++ it){ans.emplace_back(it->second);}return ans;}
};

代码解析&运行解析

这段代码定义了一个名为 Solution 的类,类中包含一个名为 groupAnagrams 的方法。这个方法用于将一组字符串按字母异位词(anagram)分组。以下是代码的逐行解析:

class Solution {
public:vector<vector<string>> groupAnagrams(vector<string>& strs) {
  • 这段代码定义了一个类 Solution,类中包含一个公有方法 groupAnagrams。该方法接收一个引用参数 strs,它是一个字符串的向量(vector<string>),返回值是一个二维字符串向量(vector<vector<string>>)。
        unordered_map<string, vector<string>> mp;
  • 这里定义了一个名为 mp 的变量,它是一个 unordered_map,键类型是 string,值类型是 vector<string>。这个哈希映射用于将排序后的字符串(作为键)映射到原始字符串列表(作为值)。
        for (string& str: strs) {string key = str;sort(key.begin(), key.end());mp[key].emplace_back(str);}
  • 这一段代码遍历输入的字符串向量 strs
    • 对于每个字符串 str,将其复制到 key 中。
    • 通过 sort(key.begin(), key.end())key 中的字符进行排序。
    • 使用排序后的 key 作为键,将原始字符串 str 添加到 mp 字典中对应的列表中。
        vector<vector<string>> ans;
  • 创建一个空的二维字符串向量 ans,用于存储结果。
        for (auto it = mp.begin(); it != mp.end(); ++it) {ans.emplace_back(it->second);}
  • 遍历 mp 中的每一个键值对。
    • 对于每一个键值对,将值(即一个字符串列表)添加到 ans 中。
        return ans;}
};
  • 最后,返回 ans,它包含了按字母异位词分组的字符串列表。

总结:

  • 这个方法的主要作用是将输入的字符串向量按字母异位词分组。字母异位词是指由相同字母组成但顺序不同的字符串。
  • 通过对每个字符串的字符进行排序,可以生成唯一的键(排序后的字符串),用这个键来将原始字符串分组。

例如,输入 ["eat", "tea", "tan", "ate", "nat", "bat"],该方法将返回 [['eat', 'tea', 'ate'], ['tan', 'nat'], ['bat']]

让我们详细跟踪代码执行的每一步,以理解它是如何处理输入 ["eat", "tea", "tan", "ate", "nat", "bat"] 的。

假设输入是 ["eat", "tea", "tan", "ate", "nat", "bat"],代码的每一步执行结果如下:

  1. 创建 mpmp = {}(初始状态)

  2. 处理 str = "eat"

    • key = "eat"
    • sort(key.begin(), key.end()) 结果是 key = "aet"
    • mp["aet"].emplace_back("eat"),更新后的 mp 是:{"aet": ["eat"]}
  3. 处理 str = "tea"

    • key = "tea"
    • sort(key.begin(), key.end()) 结果是 key = "aet"
    • mp["aet"].emplace_back("tea"),更新后的 mp 是:{"aet": ["eat", "tea"]}
  4. 处理 str = "tan"

    • key = "tan"
    • sort(key.begin(), key.end()) 结果是 key = "ant"
    • mp["ant"].emplace_back("tan"),更新后的 mp 是:{"aet": ["eat", "tea"], "ant": ["tan"]}
  5. 处理 str = "ate"

    • key = "ate"
    • sort(key.begin(), key.end()) 结果是 key = "aet"
    • mp["aet"].emplace_back("ate"),更新后的 mp 是:{"aet": ["eat", "tea", "ate"], "ant": ["tan"]}
  6. 处理 str = "nat"

    • key = "nat"
    • sort(key.begin(), key.end()) 结果是 key = "ant"
    • mp["ant"].emplace_back("nat"),更新后的 mp 是:{"aet": ["eat", "tea", "ate"], "ant": ["tan", "nat"]}
  7. 处理 str = "bat"

    • key = "bat"
    • sort(key.begin(), key.end()) 结果是 key = "abt"
    • mp["abt"].emplace_back("bat"),更新后的 mp 是:{"aet": ["eat", "tea", "ate"], "ant": ["tan", "nat"], "abt": ["bat"]}

遍历 mp,将每个值(字符串列表)添加到 ans 中:

  • ans = [["eat", "tea", "ate"], ["tan", "nat"], ["bat"]]

返回 ans,最终结果是:[['eat', 'tea', 'ate'], ['tan', 'nat'], ['bat']]

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/17126.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

机器学习笔记——K近邻算法、手写数字识别

KNN算法 “物以类聚&#xff0c;人以群分”相似的数据往往拥有相同的类别 其大概原理就是一个样本归到哪一类&#xff0c;当前样本需要归到频次最高的哪个类去 也就是说有一个待分类的样本&#xff0c;然后跟他周围的k个样本来看&#xff0c;k中哪一个类最多&#xff0c;待分类…

Oracle数据库Day01-SELECT语句

一、SQL语句 1. 环境配置与准备 linux端oracle用户打开监听//查看监听状态与开始监听 lsnrctl status lsnrctl start开启数据库sqlplus / as sysdba startup;解锁hr用户样例数据库&#xff0c;给hr用户设置密码并且连接alter user hr account unlock; alter user hr identifie…

2024爆款神器!会声会影2024旗舰版,让你的视频制作技能暴涨,不学真的亏大了!

在数字内容创作的时代&#xff0c;视频编辑已经成为连接创意与现实的重要桥梁。无论是个人Vlog制作、在线教育课程、企业宣传还是专业影视制作&#xff0c;高效而强大的视频编辑软件成为了必不可少的工具。会声会影2024旗舰版&#xff0c;作为一款集先进技术与用户友好界面设计…

常用API(正则表达式、爬取、捕获分组和非捕获分组 )

1、正则表达式 练习——先爽一下正则表达式 正则表达式可以校验字符串是否满足一定的规则&#xff0c;并用来校验数据格式的合法性。 需求&#xff1a;假如现在要求校验一个qq号码是否正确。 规则&#xff1a;6位及20位之内&#xff0c;0不能在开头&#xff0c;必须全部是数字…

30.哀家要长脑子了!---栈与队列

1.388. 文件的最长绝对路径 - 力扣&#xff08;LeetCode&#xff09; 其实看懂了就还好 用一个栈来保存所遍历过最大的文件的绝对路径的长度&#xff0c;栈顶元素是文件的长度&#xff0c;栈中元素的个数是该文件目录的深度&#xff0c;非栈顶元素就是当时目录的长度 检查此…

Qt 5前后调色板差异变化

Qt 5之前&#xff1a; QPalette palette;//调色板 设置背景颜色 palette.setColor(QPalette::Backgound, color...);Qt 5之后&#xff1a; 由原有的 Background 模式 更新为 Window 模式 QPalette palette;//调色板 设置背景颜色 palette.setColor(QPalette::Window, color..…

10.SpringBoot 统一处理功能

文章目录 1.拦截器1.1在代码中的应用1.1.1定义拦截器1.1.2注册配置拦截器 1.2拦截器的作用1.3拦截器的实现 2.统一数据返回格式2.1 为什么需要统⼀数据返回格式&#xff1f;2.2 统⼀数据返回格式的实现 3.统一异常处理4.SpringBoot专业版创建项目无Java8版本怎么办&#xff1f;…

nodejs安装配置

nodejs安装 打开nodejs官网(https://nodejs.org/en/download/package-manager)&#xff0c;参考安装步骤操作。 更新镜像源 输入以下命令&#xff0c;将npm的镜像源设置为淘宝镜像。网上资料中&#xff0c;淘宝镜像地址多为https://registry.npm.taobao.org&#xff0c;这个…

【MATLAB源码-第67期】基于麻雀搜索算法(SSA)的无人机三维地图路径规划,输出最短路径和适应度曲线。

操作环境&#xff1a; MATLAB 2022a 1、算法描述 麻雀搜索算法&#xff08;Sparrow Search Algorithm, SSA&#xff09;是一种新颖的元启发式优化算法&#xff0c;它受到麻雀社会行为的启发。这种算法通过模拟麻雀的食物搜索行为和逃避天敌的策略来解决优化问题。SSA通过模拟…

【C++】:vector容器的基本使用

目录 &#x1f352;1&#xff0c;vector的介绍&#x1f352;2&#xff0c;vector的使用&#x1f42f;2.1 vector的构造&#x1f981;2.2 vector iterator 的使用&#x1f33d;2.3 vector 空间增长问题&#x1f353;2.4 vector 增删查改&#x1f42f;2.5 vector 访问及遍历&…

雷军-2022.8小米创业思考-9-爆品模式:产品力超群,具有一流口碑,最终实现海量长销的产品。人人都向往;做减法;重组创新;小白模式

第九章 爆品模式 小米方法论的第三个关键词&#xff0c;就是一切以产品为出发点&#xff0c;打造爆品模式。 大多数人对“爆品”的着眼点仅在于“爆”&#xff0c;也就是产品卖得好。希望产品大卖这没有错&#xff0c;但是“爆”是“品”的结果&#xff0c;爆品是打造出来的&…

【附代码】@hydra.main 没有返回值,如何解决函数返回?

hydra.main 是一个 Python 装饰器&#xff0c;通常与 Hydra 深度学习框架一起使用。它的作用是标识 Hydra 配置文件中的主函数。在 Hydra 中&#xff0c;主函数是一个负责组织整个程序执行流程的函数。这个装饰器告诉 Hydra 这个函数是主函数&#xff0c;但并不要求它有返回值。…

闲话 .NET(7):.NET Core 能淘汰 .NET FrameWork 吗?

前言 虽然说&#xff0c;目前 .NET FrameWork 上的大部分类都已经移植到 .NET Core 上&#xff0c;而且 .NET FrameWork 也已经停止了更新&#xff0c;未来必然是 .NET Core 的天下&#xff0c;但要说现在 .NET Core 就能淘汰 .NET FrameWork&#xff0c;我觉得为时尚早&#…

知识付费已达天花板,太多的割韭菜案例了!

一张图片在网上传播&#xff0c;照片有点讽刺&#xff0c;里面两个人&#xff1a;一个人是OpenAI首席执行官萨姆奥特曼&#xff08;Sam Altman&#xff09;&#xff0c;一位是自称清华博士的网络大V李先生&#xff0c;他们被并称为“AI界两大巨头”。 不过贡献不同&#xff0c…

【AD21】钻孔文件的输出

钻孔文件包含了所有需要在PCB上钻孔的位置、孔径和类型&#xff08;如通孔、盲孔、埋孔&#xff09;的详细信息。板厂可以使用这个文件来控制钻孔机进行精确钻孔。 在PCB源文件页面&#xff0c;菜单栏中点击文件->制造输出->NC Drill Files。 在弹出的新界面&#xff0c…

Linux 信号量

Linux 信号量 一、信号量的基本概念1. 计数信号量&#xff08;Counting Semaphore&#xff09;2. 二进制信号量&#xff08;Binary Semaphore&#xff09; 二 、使用场景1. 信号量需要用到的库系统V IPC头文件 2. 代码演示1. 头文件和结构体定义2. 主函数3. 创建/获取共享内存4…

Webpack性能调优:从加载器到插件的全面优化

Webpack 是一个模块打包工具&#xff0c;它将项目中的各种资源&#xff08;JavaScript、CSS、图片等&#xff09;转换成一个或多个浏览器可识别的输出文件。优化 Webpack 的性能主要涉及减少构建时间、减小输出文件大小和提高应用加载速度。 2500G计算机入门到高级架构师开发资…

解析Spring Bean对象的作用域机制

1. 作用域范围 1. singleton单例&#xff1a;在整个SpringBoot应用中&#xff0c;只创建bean的一个实例; 2. propotye多例&#xff1a;每次注入或者通过Spring应用上下文获取的时候&#xff0c;都会创建一个新的bean实例; 3. request请求&#xff1a;一次http请求&#xff0c;…

C++240527

定义自己的命名空间 my_sapce&#xff0c;在 my_sapce 中定义 string 类型的变量 s1&#xff0c;再 定义一个函数 完成 对字符串的逆置 。 #include <iostream>//导入 标准命名空间&#xff0c;cout 和 endl 标识符 存在于标准命名空间中 using namespace std;//定义了自…

springboot+vue+mybatis基于java web的公益网站的设计与实现+jsp+PPT+论文+讲解+售后

现代经济快节奏发展以及不断完善升级的信息化技术&#xff0c;让传统数据信息的管理升级为软件存储&#xff0c;归纳&#xff0c;集中处理数据信息的管理方式。本公益网站就是在这样的大环境下诞生&#xff0c;其可以帮助管理者在短时间内处理完毕庞大的数据信息&#xff0c;使…