【Leetcode】17. 电话号码的字母组合

2019-08-05  本文已影响0人  haha2333

题目链接:https://leetcode-cn.com/problems/letter-combinations-of-a-phone-number/

总体思路:for循环内部,字母自由组合嘛。可是,我要循环多少层呢?这要根据用户的输入的长度决定,可是for循环的层数怎么动态写?貌似不能。于是快速的瞄了一眼答案。原来要用递归函数!!!

使用递归函数,判断是否匹配到参数字符串(即下文的23)的尽头,是,则返回结果。不是,则继续搭配。

所以说!当我们遇到不具体的循环次数的时候,递归函数是一个很好的选择。

以下是我的答案

const obj = {
    2: ["a", "b", "c"],
    3: ["d", "e", "f"],
    4: ["g", "h", "i"],
    5: ["j", "k", "l"],
    6: ["m", "n", "o"],
    7: ["p", "q", "r", "s"],
    8: ["t", "u", "v"],
    9: ["w", "x", "y", "z"],
}
var t=1
function digui(arr, str,res) {
    let resArr = []
    for (let i = 0; i < arr.length; i++){
        for (let j = 0; j < obj[str].length; j++){
            resArr.push(arr[i] + obj[str][j])
        }
    }   
    t++
    arr = resArr
    str = res[t]
    if (str) {
        digui(arr, str,res)
    }
    else {
        console.log(arr)
        return 0
    }
}

function outer(x) {
    let res = x.toString().split('')
    let arr = obj[res[0]]//第一个数字
    let str = res[t]
    digui(arr, str, res)
}
outer(234)

本来是想用还顺便用闭包和匿名函数的。然而匿名函数要怎么递归?
其实这个之前也复习过了。使用argumentscallee方法就可以实现匿名函数的递归

arguments.callee(参数)

写到这里,又发现了一些坑。

function outer() {
    let res = 23
    return function(res){
        console.log(res)  //undefined
}

知道了吧,闭包里面的res首先应当是传入的参数的res,然后才是闭包外面的res

上一篇下一篇

猜你喜欢

热点阅读