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
相关推荐
带多刺的玫瑰42 分钟前
Leecode刷题C语言之统计不是特殊数字的数字数量
java·c语言·算法
爱敲代码的憨仔44 分钟前
《线性代数的本质》
线性代数·算法·决策树
yigan_Eins1 小时前
【数论】莫比乌斯函数及其反演
c++·经验分享·算法
阿史大杯茶1 小时前
AtCoder Beginner Contest 381(ABCDEF 题)视频讲解
数据结构·c++·算法
დ旧言~2 小时前
【高阶数据结构】图论
算法·深度优先·广度优先·宽度优先·推荐算法
张彦峰ZYF2 小时前
投资策略规划最优决策分析
分布式·算法·金融
The_Ticker2 小时前
CFD平台如何接入实时行情源
java·大数据·数据库·人工智能·算法·区块链·软件工程
Lenyiin3 小时前
02.06、回文链表
数据结构·leetcode·链表
爪哇学长3 小时前
双指针算法详解:原理、应用场景及代码示例
java·数据结构·算法
Dola_Pan3 小时前
C语言:数组转换指针的时机
c语言·开发语言·算法