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
相关推荐
zheyutao10 分钟前
字符串哈希
算法
A尘埃19 分钟前
保险公司车险理赔欺诈检测(随机森林)
算法·随机森林·机器学习
大江东去浪淘尽千古风流人物1 小时前
【VLN】VLN(Vision-and-Language Navigation视觉语言导航)算法本质,范式难点及解决方向(1)
人工智能·python·算法
努力学算法的蒟蒻2 小时前
day79(2.7)——leetcode面试经典150
算法·leetcode·职场和发展
2401_841495642 小时前
【LeetCode刷题】二叉树的层序遍历
数据结构·python·算法·leetcode·二叉树··队列
AC赳赳老秦2 小时前
2026国产算力新周期:DeepSeek实战适配英伟达H200,引领大模型训练效率跃升
大数据·前端·人工智能·算法·tidb·memcache·deepseek
2401_841495642 小时前
【LeetCode刷题】二叉树的直径
数据结构·python·算法·leetcode·二叉树··递归
budingxiaomoli2 小时前
优选算法-字符串
算法
我是咸鱼不闲呀2 小时前
力扣Hot100系列19(Java)——[动态规划]总结(上)(爬楼梯,杨辉三角,打家劫舍,完全平方数,零钱兑换)
java·leetcode·动态规划
qq7422349843 小时前
APS系统与OR-Tools完全指南:智能排产与优化算法实战解析
人工智能·算法·工业·aps·排程