Golang | Leetcode Golang题解之第17题电话号码的字母组合

题目:

题解:

Go 复制代码
var phoneMap map[string]string = map[string]string{
    "2": "abc",
    "3": "def",
    "4": "ghi",
    "5": "jkl",
    "6": "mno",
    "7": "pqrs",
    "8": "tuv",
    "9": "wxyz",
}

var combinations []string

func letterCombinations(digits string) []string {
    if len(digits) == 0 {
        return []string{}
    }
    combinations = []string{}
    backtrack(digits, 0, "")
    return combinations
}

func backtrack(digits string, index int, combination string) {
    if index == len(digits) {
        combinations = append(combinations, combination)
    } else {
        digit := string(digits[index])
        letters := phoneMap[digit]
        lettersCount := len(letters)
        for i := 0; i < lettersCount; i++ {
            backtrack(digits, index + 1, combination + string(letters[i]))
        }
    }
}
相关推荐
jieyucx14 小时前
Go 语言 JSON 序列化与反序列化
开发语言·golang·json·序列化
菜菜的顾清寒14 小时前
力扣HOT100(34)图论-岛屿数量
算法·leetcode·图论
圣保罗的大教堂14 小时前
leetcode 2657. 找到两个数组的前缀公共数组 中等
leetcode
洛水水15 小时前
【力扣100题】57.合并区间
算法·leetcode
圣保罗的大教堂15 小时前
leetcode 33. 搜索旋转排序数组 中等
leetcode
AKA__Zas15 小时前
芝士算法 (双指针篇2.0)
java·数据结构·leetcode·学习方法
如竟没有火炬15 小时前
有序矩阵中第K小的元素
数据结构·线性代数·算法·leetcode·矩阵·深度优先
洛水水15 小时前
【力扣100题】63.最小覆盖子串
算法·leetcode
z2005093016 小时前
今日算法(带回文问题的回溯)
算法·leetcode·回溯
洛水水16 小时前
【力扣100题】55.编辑距离
算法·leetcode·动态规划