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
相关推荐
jiao000011 小时前
数据结构——队列
c语言·数据结构·算法
迷迭所归处2 小时前
C++ —— 关于vector
开发语言·c++·算法
leon6252 小时前
优化算法(一)—遗传算法(Genetic Algorithm)附MATLAB程序
开发语言·算法·matlab
CV工程师小林2 小时前
【算法】BFS 系列之边权为 1 的最短路问题
数据结构·c++·算法·leetcode·宽度优先
Navigator_Z3 小时前
数据结构C //线性表(链表)ADT结构及相关函数
c语言·数据结构·算法·链表
Aic山鱼3 小时前
【如何高效学习数据结构:构建编程的坚实基石】
数据结构·学习·算法
天玑y3 小时前
算法设计与分析(背包问题
c++·经验分享·笔记·学习·算法·leetcode·蓝桥杯
sjsjs114 小时前
【数据结构-一维差分】力扣1893. 检查是否区域内所有整数都被覆盖
数据结构·算法·leetcode
redcocal4 小时前
地平线秋招
python·嵌入式硬件·算法·fpga开发·求职招聘
m0_571957584 小时前
Java | Leetcode Java题解之第406题根据身高重建队列
java·leetcode·题解