电话号码的字母组合-中等

难度:中等

题目描述:
给定一个仅包含数字 2-9 的字符串,返回所有它能表示的字母组合。
给出数字到字母的映射如下(与电话按键相同)。注意 1 不对应任何字母。

示例:

输入:"23"
输出:["ad", "ae", "af", "bd", "be", "bf", "cd", "ce", "cf"].
1
2

解题思路:
回朔算法

var letterCombinations = function (digits) {
  if (digits.length === 0) return [];
  const map = new Map([
    ["2", "abc"],
    ["3", "def"],
    ["4", "ghi"],
    ["5", "jkl"],
    ["6", "mno"],
    ["7", "pqrs"],
    ["8", "tuv"],
    ["9", "wxyz"],
  ]);
  let result = [];
  const getResult = (str, index) => {
    if (index === digits.length) {
      result.push(str);
      return;
    }
    let num = digits[index];
    let strs = map.get(num);
    for (let i = 0; i < strs.length; i++) {
      getResult(str + strs[i], index + 1);
    }
  };
  getResult("", 0);
  return result;
};
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
最后更新时间: 6/9/2020, 8:21:32 PM