【每天学习一点算法 2026/03/16】电话号码的字母组合

每天学习一点算法 2026/03/16

题目:电话号码的字母组合

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

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

我们可以把每个数字对应的字母情况当做树的节点,然后统计路径结构即可。

比如,'26',对应 a b cm n o,对应树结构如下:

复制代码
          ' '
    /      |      \
   a       b       c
 / | \   / | \   / | \
m  n  o m  n  o m  n  o

这种结构就好处理多了,我们遍历所有路径统计结果就行了。

typescript 复制代码
function letterCombinations(digits: string): string[] {
  // 数字字母映射表
  const dist = {
    '2': ['a', 'b', 'c'],
    '3': ['d', 'e', 'f'],
    '4': ['g', 'h', 'i'],
    '5': ['j', 'k', 'l'],
    '6': ['m', 'n', 'o'],
    '7': ['p', 'q', 'r', 's'],
    '8': ['t', 'u', 'v'],
    '9': ['w', 'x', 'y', 'z'],
  }
  const resArr = [] // 结果数组
  // 递归辅助函数
  function helper (digits: string, index: number, str: string) {
    if (index === digits.length) {
      // 当前路径走到末尾 记录结果并回归
      resArr.push(str)
      return
    }
    const letters = dist[digits[index]] // 获取当前数字对应的字母
    for (let i of letters) {
      // 记录当前digits索引和结果字符串
      let currentIndex = index
      let currentStr = str
      // 更新digits索引和结果字符串传入下一层递归
      currentStr += i
      currentIndex++
      helper(digits, currentIndex, currentStr)
    }
  }
	// 初始传入指针和空字符串
  helper(digits, 0, '')

  return resArr
};

题目来源:力扣(LeetCode)

相关推荐
Lee川2 小时前
时空迷宫探险记:从O(1)到O(2^n)的算法进化论
算法·面试
KangJX2 小时前
Matrix获取卡顿堆栈 (Point Stack)
算法·客户端
靠沿2 小时前
【优选算法】专题十三——队列+宽搜(BFS)
算法·宽度优先
做cv的小昊2 小时前
大语言模型系统:【CMU 11-868】课程学习笔记06——Transformer学习(Transformer)
笔记·学习·语言模型
ccLianLian2 小时前
算法·字符串哈希
算法·哈希算法
SongYuLong的博客2 小时前
Linux IPC进程通信几种方法
linux·运维·算法
像污秽一样3 小时前
算法设计与分析-习题6.1
数据结构·算法
北京地铁1号线3 小时前
8.2 对比学习的损失函数
算法·机器学习·损失函数·对比学习
样例过了就是过了3 小时前
LeetCode热题100 分割回文串
数据结构·c++·算法·leetcode·深度优先·dfs