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]))
        }
    }
}
相关推荐
Mr_Xuhhh31 分钟前
LeetCode 热题 100 刷题笔记:高频面试题详解(215 & 347)
算法·leetcode·排序算法
童话ing39 分钟前
【LeetCode】239.滑动窗口最大值
数据结构·算法·leetcode·golang
不会写DN1 小时前
Go 中最主流 JWT 库 jwt -go
开发语言·后端·golang
_日拱一卒1 小时前
LeetCode:和为K的子数组
算法·leetcode·职场和发展
Mr_Xuhhh2 小时前
LeetCode 热题 100 刷题笔记:数组与排列的经典解法
数据结构·算法·leetcode
liuqun03192 小时前
go进阶之gc
开发语言·后端·golang
老四啊laosi2 小时前
[双指针] 3. 力扣--快乐数
算法·leetcode·快慢指针
古城小栈2 小时前
go核武器——pprof 性能分析
golang
会编程的土豆2 小时前
leetcode hot 100 之哈希
算法·leetcode·哈希算法
_深海凉_2 小时前
LeetCode热题100-反转链表
python·leetcode·链表