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
相关推荐
香菜大丸9 分钟前
链表的归并排序
数据结构·算法·链表
jrrz082810 分钟前
LeetCode 热题100(七)【链表】(1)
数据结构·c++·算法·leetcode·链表
oliveira-time21 分钟前
golang学习2
算法
南宫生1 小时前
贪心算法习题其四【力扣】【算法学习day.21】
学习·算法·leetcode·链表·贪心算法
懒惰才能让科技进步2 小时前
从零学习大模型(十二)-----基于梯度的重要性剪枝(Gradient-based Pruning)
人工智能·深度学习·学习·算法·chatgpt·transformer·剪枝
Ni-Guvara2 小时前
函数对象笔记
c++·算法
泉崎3 小时前
11.7比赛总结
数据结构·算法
你好helloworld3 小时前
滑动窗口最大值
数据结构·算法·leetcode
AI街潜水的八角3 小时前
基于C++的决策树C4.5机器学习算法(不调包)
c++·算法·决策树·机器学习
白榆maple4 小时前
(蓝桥杯C/C++)——基础算法(下)
算法