LeetCode-热题100:17.电话号码的字母组合

题目描述

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

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

示例 1:

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

示例 2:

输入: digits = ""
输出: []

示例 3:

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

提示:

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

代码及注释

go 复制代码
func letterCombinations(digits string) []string {
    // 定义数字对应的字母映射表
    m := []string{"abc", "def", "ghi", "jkl", "mno", "pqrs", "tuv", "wxyz"}

    // 初始化结果切片和当前路径切片
    res, path := make([]string, 0), make([]byte, 0)

    // 如果输入的数字字符串为空,则直接返回空结果切片
    if digits == "" {
        return res
    }

    // 定义深度优先搜索函数
    var dfs func(digits string, pos int)
    dfs = func(digits string, pos int) {
        // 如果当前位置已经遍历到数字字符串的末尾
        if pos == len(digits) {
            // 将当前路径切片转换为字符串,并添加到结果切片中
            tmp := string(path)
            res = append(res, tmp)
            return
        }

        // 获取当前位置对应的数字,并获取其对应的字母字符串
        digit := int(digits[pos] - '0')
        str := m[digit-2]

        // 遍历当前数字对应的字母字符串中的每个字母
        for i := 0; i < len(str); i++ {
            // 将当前字母添加到路径切片中,并继续深度优先搜索下一个位置的数字
            path = append(path, str[i])
            dfs(digits, pos+1)
            // 回溯,将当前字母从路径切片中移除
            path = path[:len(path)-1]
        }
    }

    // 从第一个位置开始进行深度优先搜索
    dfs(digits, 0)

    // 返回结果切片
    return res
}
相关推荐
IronMurphy5 小时前
【算法四十三】279. 完全平方数
算法
墨染天姬5 小时前
【AI】Hermes的GEPA算法
人工智能·算法
papership6 小时前
【入门级-数据结构-3、特殊树:完全二叉树的数组表示法】
数据结构·算法·链表
smj2302_796826526 小时前
解决leetcode第3911题.移除子数组元素后第k小偶数
数据结构·python·算法·leetcode
Beginner x_u6 小时前
链表专题:JS 实现原理与高频算法题总结
javascript·算法·链表
_深海凉_9 小时前
LeetCode热题100-寻找两个正序数组的中位数
算法·leetcode·职场和发展
踩坑记录10 小时前
leetcode hot100 寻找两个正序数组的中位数 hard 二分查找 双指针
leetcode
旖-旎10 小时前
深搜练习(电话号码字母组合)(3)
c++·算法·力扣·深度优先遍历
谭欣辰10 小时前
C++快速幂完整实战讲解
算法·决策树·机器学习
Mr_pyx11 小时前
【LeetHOT100】随机链表的复制——Java多解法详解
算法·深度优先