LeetCode电话号码的字母组合

问题描述

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

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


示例 1:

输入:digits = "23"

输出:["ad","ae","af","bd","be","bf","cd","ce","cf"]

示例 2:

输入:digits = ""

输出:[]

示例 3:

输入:digits = "2"

输出:["a","b","c"]

解题思路:

javascript 复制代码
var letterCombinations = function(digits) {
    let phone = {  //电话数字到字母的映射
        '2': 'abc',
        '3': 'def',
        '4': 'ghi',
        '5': 'jkl',
        '6': 'mno',
        '7': 'pqrs',
        '8': 'tuv',
        '9': 'wxyz'
    };
    let arr = [];
    for (let i of digits) {
        arr = merge(arr, phone[i]);
    }
    return arr;
};

const merge = (arr, str) => {  //将str每个字符与arr已有字符串进行组合
    let newArr = [];
    if (arr.length === 0) {  //arr是空数组
        for (let i of str) {
            newArr.push(i);
        }
    } else {  //非空数组
        for (let i of arr) {  //将arr已有字符串与str组合,存入newArr
            for (let j of str) {
                newArr.push(i + j);
            }
        }
    }
    return newArr;
}

代码解释:

这段代码是一个JavaScript函数,名为letterCombinations,它的作用是根据输入的数字字符串生成所有可能的字母组合。这些字母组合是根据电话键盘上数字与字母的对应关系来生成的。下面是对代码的逐行解释:

  1. 定义了一个名为letterCombinations的函数,它接受一个参数digits,这个参数是一个字符串,代表一系列的数字。

  2. 在函数内部,定义了一个名为phone的对象,它是一个映射表,将数字映射到它们在电话键盘上对应的字母。例如,数字2映射到'abc',数字3映射到'def',以此类推。

  3. 定义了一个空数组arr,用于存储生成的字母组合。

  4. 使用for...of循环遍历digits字符串中的每个字符i

  5. 对于每个字符i,调用merge函数,将arr数组和phone[i](即对应数字的字母字符串)合并,并将结果重新赋值给arr

  6. 定义了一个名为merge的辅助函数,它接受两个参数:arr(一个字符串数组)和str(一个字符串)。

  7. merge函数内部,定义了一个空数组newArr,用于存储合并后的结果。

  8. 如果arr的长度为0(即为空数组),则将str中的每个字符添加到newArr中。

  9. 如果arr非空,使用嵌套的for...of循环将arr中的每个字符串istr中的每个字符j组合,并将组合后的字符串添加到newArr中。

  10. merge函数返回newArr,即合并后的新数组。

  11. 最终,letterCombinations函数返回填充了所有可能字母组合的arr数组。

这个函数可以处理像"23"这样的输入,并返回所有可能的字母组合,例如["ad", "ae", "af", "bd", "be", "bf", "cd", "ce", "cf"]。它通过递归地将每个数字对应的所有字母与之前生成的字母组合进行合并来实现这一点。

提示:

for...of 语句创建一个循环来迭代可迭代的对象。在 ES6 中引入的 for...of 循环,以替代 for...inforEach() ,并支持新的迭代协议。for...of 允许你遍历 Arrays(数组), Strings(字符串), Maps(映射), Sets(集合)等可迭代的数据结构等。

示例:

javascript 复制代码
// array-example.js
const iterable = ['mini', 'mani', 'mo'];
 
for (const value of iterable) {
  console.log(value);
}
 
// Output:
// mini
// mani
// mo
相关推荐
山烛4 分钟前
KNN 算法中的各种距离:从原理到应用
人工智能·python·算法·机器学习·knn·k近邻算法·距离公式
guozhetao17 分钟前
【ST表、倍增】P7167 [eJOI 2020] Fountain (Day1)
java·c++·python·算法·leetcode·深度优先·图论
吃着火锅x唱着歌19 分钟前
LeetCode 611.有效三角形的个数
算法·leetcode·职场和发展
技术卷24 分钟前
详解力扣高频SQL50题之619. 只出现一次的最大数字【简单】
sql·leetcode·oracle
CHANG_THE_WORLD3 小时前
金字塔降低采样
算法·金字塔采样
不知天地为何吴女士5 小时前
Day32| 509. 斐波那契数、70. 爬楼梯、746. 使用最小花费爬楼梯
算法
小坏坏的大世界5 小时前
C++ STL常用容器总结(vector, deque, list, map, set)
c++·算法
励志要当大牛的小白菜8 小时前
ART配对软件使用
开发语言·c++·qt·算法
qq_513970448 小时前
力扣 hot100 Day56
算法·leetcode
PAK向日葵9 小时前
【算法导论】如何攻克一道Hard难度的LeetCode题?以「寻找两个正序数组的中位数」为例
c++·算法·面试