【每天学习一点算法 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)

相关推荐
Alice-YUE2 分钟前
前端性能优化完全指南:从指标到实战
前端·学习·性能优化
paeamecium9 分钟前
【PAT甲级真题】- Recover the Smallest Number (30)
数据结构·算法·pat考试·pat
Dillon Dong11 分钟前
【风电控制】变流器转矩控制回路深度解析:从指令生成到闭环控制
算法·变流器·风电控制
玛丽莲茼蒿16 分钟前
Leetcode hot100 在排序数组中查找元素的第一个和最后一个位置【中等】
数据结构·算法
墨染天姬21 分钟前
[AI]OPENAI的PPO算法
人工智能·算法
你数过天上的星星吗22 分钟前
Python学习笔记二(函数、类与对象)
笔记·python·学习
cici1587438 分钟前
含风光储燃的微电网能量管理系统(PSO优化)
算法
stm32 菜鸟39 分钟前
nucleo-f411re学习记录-11,蓝牙模块HC-05
学习
我是发哥哈39 分钟前
三款主流AI视频生成模型商用能力对比与选型分析
大数据·人工智能·学习·ai·chatgpt·aigc·音视频
Das11 小时前
图像色彩迁移技术算法及基本原理
算法