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]))
        }
    }
}
相关推荐
小李小李快乐不已7 分钟前
动态规划理论基础
数据结构·c++·算法·leetcode·动态规划
圣保罗的大教堂15 分钟前
leetcode 1351. 统计有序矩阵中的负数 简单
leetcode
Tisfy18 分钟前
LeetCode 1351.统计有序矩阵中的负数:O(m+n)时间复杂度——抽象题解
算法·leetcode·矩阵·题解·遍历
小李小李快乐不已33 分钟前
算法技巧理论基础
数据结构·c++·算法·leetcode·hot100
思成Codes43 分钟前
Go语言的多返回值是如何实现的?
开发语言·后端·golang
Grassto1 小时前
Go 是如何解析 `import path` 的?第三方包定位原理
开发语言·golang·go module·go import
福大大架构师每日一题1 小时前
go-zero v1.9.4 版本发布详解:云原生适配升级与稳定性性能全面提升
开发语言·云原生·golang
sin_hielo1 小时前
leetcode 1351
数据结构·算法·leetcode
雪花desu1 小时前
【Hot100-Java中等】:字母异位词分组
java·算法·leetcode·哈希表
Word码1 小时前
LeetCode283. 移动零(双指针精讲)
算法·leetcode·职场和发展