【LeetCode 热题100】17:电话号码的字母组合(详细解析)(Go语言版)

☎️ LeetCode 17. 电话号码的字母组合(回溯 + DFS + 详解)

📌 题目描述

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

数字到字母的映射如下(与电话按键相同):

复制代码
2 -> abc
3 -> def
4 -> ghi
5 -> jkl
6 -> mno
7 -> pqrs
8 -> tuv
9 -> wxyz

示例:

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

💡 解题思路

这道题属于回溯算法的经典题型。类似的题目还有全排列、子集生成等。

✅ 关键点:

  1. 每一位数字对应多个字母,需要依次尝试。
  2. 每次从当前位置开始尝试不同的字母,然后递归地构建下一个字符。
  3. 递归出口是当组合长度等于输入数字的长度。

✍️ 回溯结构大致如下:

go 复制代码
func backtrack(path string, index int) {
    if len(path) == len(digits) {
        res = append(res, path)
        return
    }
    for _, ch := range digitMap[digits[index]] {
        backtrack(path + string(ch), index + 1)
    }
}

💻 Go 实现代码

go 复制代码
func letterCombinations(digits string) []string {
    if digits == "" {
        return []string{}
    }

    digitMap := map[byte]string{
        '2': "abc", '3': "def", '4': "ghi",
        '5': "jkl", '6': "mno", '7': "pqrs",
        '8': "tuv", '9': "wxyz",
    }

    var res []string

    var backtrack func(index int, path string)
    backtrack = func(index int, path string) {
        if index == len(digits) {
            res = append(res, path)
            return
        }

        letters := digitMap[digits[index]]
        for i := 0; i < len(letters); i++ {
            backtrack(index+1, path+string(letters[i]))
        }
    }

    backtrack(0, "")
    return res
}

⏱️ 复杂度分析

项目 复杂度
时间复杂度 O(3\^n \\cdot 4\^m),其中 n 是出现 3 个字母的数字个数,m 是出现 4 个字母的数字个数
空间复杂度 O(n),递归调用栈的深度

🔍 小技巧和注意点

  • 初始条件:空字符串 "" 应该直接返回空结果;
  • 回溯问题一般都要设计好递归的「终止条件」;
  • Go 语言中字符串拼接 path + string(char) 会创建新字符串,避免影响回溯路径;
  • 用 map 存储 digit → 字母 的映射比硬编码效率更高、代码更清晰。

🎯 总结

内容 要点
核心思想 回溯法构造所有可能组合
数据结构 map(映射),递归
解题模板 回溯常规套路:终止条件 + for 循环尝试每一种选择
常见考点 字符组合、搜索树、剪枝优化(可选)

📚 类似题推荐


💡 小结:

本题是回溯法的经典入门题,重点在于理解「每一步做选择 + 撤销选择」的模式。掌握之后,可以举一反三解决其他排列组合类问题。


如果你喜欢这样的讲解风格,欢迎 点赞 👍 收藏 ⭐ 评论 📝,我会持续带来更多高质量的 LeetCode 题解!

相关推荐
炬火初现13 小时前
Hot100-哈希,双指针
算法·哈希算法·散列表
weixin_3077791313 小时前
利用复变函数方法计算常见函数的傅里叶变换
算法
共享家952714 小时前
LeetCode热题100(1-7)
算法·leetcode·职场和发展
新学笺15 小时前
数据结构与算法 —— Java单链表从“0”到“1”
算法
同元软控15 小时前
首批CCF教学案例大赛资源上线:涵盖控制仿真、算法与机器人等9大方向
算法·机器人·工业软件·mworks
yiqiqukanhaiba16 小时前
Linux编程笔记2-控制&数组&指针&函数&动态内存&构造类型&Makefile
数据结构·算法·排序算法
PKNLP16 小时前
逻辑回归(Logistic Regression)
算法·机器学习·逻辑回归
可触的未来,发芽的智生16 小时前
新奇特:神经网络的自洁之道,学会出淤泥而不染
人工智能·python·神经网络·算法·架构
come1123416 小时前
Go Modules 包管理 (Go 模块)
开发语言·后端·golang
放羊郎16 小时前
SLAM算法分类对比
人工智能·算法·分类·数据挖掘·slam·视觉·激光