电话号码的字母组合

发布于 2023-05-03 21:31:21 字数 822 浏览 33 评论 0

给定一个仅包含数字 2-9 的字符串,返回所有它能表示的字母组合。给出数字到字母的映射如下(与电话按键相同)。注意 1 不对应任何字母,输入: 23 输出: ["ad", "ae", "af", "bd", "be", "bf", "cd", "ce", "cf"]

回溯

function getLetters(digits) {
    if (!digits) return []
    const digitsMap = {
        2: 'abc',
        3: 'def',
        4: 'ghi',
        5: 'jkl',
        6: 'mno',
        7: 'pqrs',
        8: 'tuv',
        9: 'wxyz',
    }

    const res = []

    function track(s, start) {
        if (s.length === digits.length) {
            res.push(s)
            return
        }
        const letters = digitsMap[digits[start]]
        for(let i = 0;i< letters.length;i++) {
            track(s+letters[i],start+1)
        }
    }

    track('', 0)

    return res
}

console.log(getLetters('24'))
console.log(getLetters('523'))

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

关于作者

二手情话

暂无简介

0 文章
0 评论
23 人气
更多

推荐作者

qq_eQNo9e

文章 0 评论 0

内心旳酸楚

文章 0 评论 0

mb_BlPo2I8v

文章 0 评论 0

alipaysp_ZRaVhH1Dn

文章 0 评论 0

alipaysp_VP2a8Q4rgx

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文