当前位置: 首页 > news >正文

day152—回溯—电话号码的字母组合(LeetCode-17)

题目描述

给定一个仅包含数字2-9的字符串,返回所有它能表示的字母组合。答案可以按任意顺序返回。

给出数字到字母的映射如下(与电话按键相同)。注意 1 不对应任何字母。

示例 1:

输入:digits = "23"输出:["ad","ae","af","bd","be","bf","cd","ce","cf"]

示例 2:

输入:digits = "2"输出:["a","b","c"]

提示:

  • 1 <= digits.length <= 4
  • digits[i]是范围['2', '9']的一个数字。

解决方案:

这段代码的核心功能是生成电话号码数字串对应的所有字母组合(比如输入 "23" 输出 ["ad","ae","af","bd","be","bf","cd","ce","cf"]),采用「类成员变量 + 递归回溯」的传统写法实现,替代了原 lambda 表达式的递归方式,时间复杂度O(3^m × 4^n)m是对应 3 个字母的数字个数,n是对应 4 个字母的数字个数),空间复杂度O(len)len为数字串长度,递归栈 + 路径字符串开销),是该问题的经典回溯解法。

核心逻辑(总体)

代码通过类成员变量共享递归所需的核心数据,再通过深度优先搜索(DFS)的回溯思想,逐位遍历数字对应的字母,拼接出所有可能的组合:

  1. 类成员变量设计
    • MAPPING:固定的数字→字母映射表,对应电话键盘的数字 - 字母关系;
    • ans:存储最终所有字母组合的结果数组;
    • path:临时存储当前拼接的字母路径(比如处理到第 2 位时,path 可能是 "a");
    • digits/len:存储输入的数字串和其长度,供递归函数访问;
  2. 递归辅助函数dfs
    • 参数i:表示当前处理到数字串的第i位;
    • 终止条件:i == len时,说明所有数字都处理完毕,将当前路径path加入结果数组ans
    • 核心逻辑:取出第i位数字对应的字母集,遍历每个字母并填入path[i],递归处理下一位数字(i+1),完成回溯遍历;
  3. 主函数letterCombinations
    • 边界处理:输入数字串为空时直接返回空数组;
    • 初始化成员变量:将输入的数字串、长度、路径字符串(初始化长度为数字串长度)赋值给类成员;
    • 启动递归:调用dfs(0)从第 0 位数字开始处理,最终返回结果数组ans

总结

  1. 核心思路:用回溯法遍历所有可能的字母组合,逐位确定数字对应的字母,递归到底时保存完整组合;
  2. 关键设计:将递归所需的结果、路径、输入等数据设为类成员变量,避免递归函数传递大量参数,简化逻辑;

函数源码:

#include <vector> #include <string> using namespace std; class Solution { public: // 数字到字母的映射表(类内私有常量) const string MAPPING[10] = {"", "", "abc", "def", "ghi", "jkl", "mno", "pqrs", "tuv", "wxyz"}; // 结果数组(类内私有成员,供辅助函数访问) vector<string> ans={}; // 临时存储当前路径的字符串 string path=""; // 输入的数字字符串 string digits=""; // 数字字符串的长度 int len=digits.length(); // 递归辅助函数 void dfs(int i) { // 递归终止条件:遍历完所有数字 if (i == len) { ans.emplace_back(path); return; } // 获取当前数字对应的字母集 string letters = MAPPING[digits[i] - '0']; // 遍历当前数字的所有可能字母 for (auto c : letters) { path[i] = c; // 记录当前位置的字母 dfs(i + 1); // 递归处理下一个数字 } } vector<string> letterCombinations(string digits) { this->len = digits.length(); // 边界条件:空字符串直接返回空数组 if (this->len == 0) { return {}; } // 初始化成员变量 this->digits = digits; this->path = string(this->len, 0); // 初始化路径字符串长度为数字长度 // 调用递归辅助函数,从第0个数字开始处理 dfs(0); return this->ans; } };
http://www.jsqmd.com/news/269126/

相关文章:

  • python基于vue的电力集团企业员工职称评定系统
  • AI 写论文哪个软件最好?实测封神!虎贲等考 AI 成毕业通关 “学术引擎”
  • python基于vue美剧观影点评网站的设计与实现
  • 上海靠谱嵌入式开发怎么选,实邦电子值得考虑吗?
  • 9 款 AI 写论文哪个好?实测虎贲等考 AI:毕业论文的学术通关全能王
  • 魔果云课|寒假录课变现密码[特殊字符]
  • 单片机毕业论文(毕设)易上手开题报告推荐
  • 【上海大学主办|应用数学会议】第六届应用数学、建模与智能计算国际学术会议(CAMMIC 2026)
  • 探秘无锡大厂成熟Foc电机控制代码,解锁电动车控制新高度
  • 深度测评8个AI论文软件,专科生搞定毕业论文+格式规范!
  • BCL-XL/CRBN PROTAC试剂盒:推动肿瘤选择性蛋白降解疗法开发的标准化工具
  • 第4章:开源模型全景图:如何选择你的技术底座
  • 一个网安老炮的私活生存指南:6年赚够4倍工资,这些野路子你敢试吗?
  • 2026-01-12 关于研发成本的思考
  • 第5章:Prompt Engineering的工程化实践
  • 基于python的校园论坛交流系统
  • 洛谷 P3748 [六省联考 2017] 摧毁“树状图”
  • 第四章:网络编程
  • 洛谷 P5071 [Ynoi Easy Round 2015] 此时此刻的光辉
  • 2026企业微信私域运营工具推荐:微盛·企微管家为何成腾讯认证增长工具
  • 大数据情感分析:助力在线社交平台的安全管理
  • 营销型网站建设避坑要点:内容本地化和广告素材匹配怎么做
  • 如何培养学生学习word的兴趣?
  • 寒假生活记录
  • 奥比中光 Gemini 336L - 调试记录(Ubuntu 24.04)
  • 2026年深圳评价高的氮化铝陶瓷片厂家推荐,主要有哪些陶瓷片品牌? - 睿易优选
  • 即插即用系列(代码实践) | AMD核心模块:自适应多尺度分解框架——纯MLP架构吊打Transformer,时间序列预测新SOTA
  • 全网最全2026研究生AI论文平台TOP9:开题文献综述神器测评
  • Spark与Flink对比:流批一体架构的技术选型
  • Office 2021安装包免费版永久使用,附永久破解工具+详细安装教程