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

【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. 递归出口是当组合长度等于输入数字的长度。

✍️ 回溯结构大致如下:

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 实现代码

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 []stringvar 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 循环尝试每一种选择
常见考点字符组合、搜索树、剪枝优化(可选)

📚 类似题推荐

  • 22. 括号生成
  • 77. 组合
  • 46. 全排列
  • 784. 字母大小写全排列

💡 小结:

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


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

相关文章:

  • 【typenum】 11 私有模块(private.rs)
  • 开机自启rc.local
  • ctr查看镜像
  • 需求文档不完整,如何确保开发理解一致?
  • STM32八股【9】-----volatile关键字
  • 学习!FastAPI
  • ubuntu安装vmware启动虚拟机失败
  • 计算机组成与体系结构:缓存一致性(Cache Coherence)
  • 第四章:WebSocket 通信机制全解与客户端发包实录
  • BOM知识点
  • 线程池学习笔记
  • Linux系统编程——system函数和popen函数的使用方法以及区别
  • 三维重建(二十三)——各种参数的测试(废案)
  • IIS入门指南:原理、部署与实战
  • 容器化:用于机器学习的 Docker 和 Kubernetes
  • SRIO(Serial RapidIO)握手流程
  • 算符优先分析之输入串分析
  • 【深度学习】残差网络(ResNet)
  • python学习day29
  • Neovim 如何安装和配置缩进标识插件 indent-blankline.nvim
  • 武汉警方通报一起故意伤害案件:1人死亡,嫌疑人已被抓获
  • 被央视曝光“废旧厂区沦为垃圾山”,江西萍乡成立调查组查处
  • 全球前瞻|特朗普19日将与俄乌总统分别通话,英国脱欧后首开英欧峰会
  • 2025吉林市马拉松开跑,用赛道绘制“博物馆之城”动感地图
  • 浙江理工大学传播系原系主任刘曦逝世,年仅44岁
  • 国家统计局公布2024年城镇单位就业人员年平均工资情况