17. 电话号码的字母组合

文章目录

题目

回溯: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

digitsi 是范围 '2', '9' 的一个数字。

代码

cpp 复制代码
class Solution {
public:
    vector<string> letterCombinations(string digits) {
        vector<string>res;
        if(digits.length()==0){
            return res;
        }
        string tmp;
        unordered_map<char,string>u_map{
            {'2',"abc"},
            {'3',"def"},
            {'4',"ghi"},
            {'5',"jkl"},
            {'6',"mno"},
            {'7',"pqrs"},
            {'8',"tuv"},
            {'9',"wxyz"}
        };
        dfs(res,digits,0,tmp,u_map);
        return res;
    }
    void dfs(vector<string>&res,string &digits,int index,string &tmp,unordered_map<char,string>&u_map){
        if(index==digits.length()){
            res.push_back(tmp);
            return;
        }
        for(auto c:u_map[digits[index]]){
            tmp.push_back(c);
            dfs(res,digits,index+1,tmp,u_map);
            tmp.pop_back();
        }

    }
};

原理图

原理解释

提示:算法流程及解释在代码中已标注

1、 边界条件

首先判断输入字符串 digits 是否为空,若为空直接返回空结果集 res,避免无效计算。

2、数字与字母的映射

使用哈希表 unordered_map 存储电话键盘上数字到对应字母的映射:

2:abc,3:def,4:ghi,5:jkl,6:mno,7:pqrs,8:tuv,9:wxyz

方便快速通过数字字符查找对应的字母集合。

  1. 临时存储

临时字符串 tmp:存储当前拼接的字母组合

结果集 res:用于存储所有符合要求的最终字母组合。

  1. 深度优先搜索(DFS)

调用递归函数 dfs,传入参数:结果集、输入数字串、当前遍历的数字下标(初始为 0)、临时字符串、字母映射表。

遍历所有数字,为每个数字选择一个字母,拼接成完整组合。

  1. DFS 递归终止条件

当递归下标 index 等于输入数字串的长度时,说明已经遍历完所有数字,完成了一次完整的字母拼接。

将此时的临时字符串 tmp 加入结果集 res,然后返回,结束当前递归分支。

  1. 递归遍历 + 回溯核心逻辑

取出当前下标对应数字的所有字母,循环遍历每一个字母:

选择字母:将当前字母添加到临时字符串 tmp 末尾(拼接组合)。

递归深入:下标 + 1,处理下一个数字,继续拼接字母。

回溯撤销:递归返回后,删除 tmp 末尾的字母(撤销当前选择),尝试循环中的下一个字母。

  1. 最终返回结果

所有递归分支执行完毕后,结果集 res 中存储了所有可能的字母组合,直接返回即可。

相关推荐
罗西的思考5 小时前
机器人 / 强化学习】HIL-SERL:人类在环驱动的具身智能进化框架
人工智能·算法·机器学习
美团技术团队8 小时前
LongCat 开源 VitaBench 2.0:长期动态智能体基准新标杆
人工智能·算法
用户8055336980315 小时前
不止三件套:QObject 属性系统全关键字与运行时反射!
c++·qt
To_OC1 天前
LC 207 课程表:刚学图论那会儿,我连这是拓扑排序都没看出来
javascript·算法·leetcode
To_OC1 天前
LC 208 实现 Trie 前缀树:曾被名字劝退,写完发现是送分题
javascript·算法·leetcode
BadBadBad__AK1 天前
线段树维护区间 k 次方和
c++·数学·算法·stl
卷无止境2 天前
Eigen 库如何借助 OpenMP 加速计算
c++·后端
_清歌2 天前
DSpark 深度解读:DeepSeek-V4 如何用「半自回归」把推理速度提升 85%
算法
统计实现局2 天前
SVD 的三步走:双对角化、Givens 收敛、排序
算法