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
}
相关推荐
Mxsoft61919 分钟前
AR远程定位偏差救场!某次现场故障,SLAM算法精准对齐设备模型!
算法·ar
Hello娃的31 分钟前
【量子力学】Hohenberg-Kohn 定理
人工智能·算法
资深web全栈开发34 分钟前
深入理解 Google Wire:Go 语言的编译时依赖注入框架
开发语言·后端·golang
老马啸西风39 分钟前
成熟企业级技术平台 MVE-010-IGA(Identity Governance & Administration,身份治理与管理)平台
人工智能·深度学习·算法·职场和发展
老马啸西风1 小时前
成熟企业级技术平台 MVE-010-app 管理平台
人工智能·深度学习·算法·职场和发展
lzh_200110121 小时前
树状数组理解
算法
历程里程碑1 小时前
C++ 6 :string类:高效处理字符串的秘密
c语言·开发语言·数据结构·c++·笔记·算法·排序算法
蓝色汪洋1 小时前
luogu迷宫寻路
算法
木头左2 小时前
自适应门限动态调整算法在量化交易策略中的应用
算法