LeetCode 17 電話號碼的字母組合

2021-10-23 21:09:52 字數 1446 閱讀 1843

17. **號碼的字母組合

給定乙個僅包含數字 2-9 的字串,返回所有它能表示的字母組合。

給出數字到字母的對映如下(與**按鍵相同)。注意 1 不對應任何字母。

示例:輸入:"23"

輸出:["ad", "ae", "af", "bd", "be", "bf", "cd", "ce", "cf"].

說明:儘管上面的答案是按字典序排列的,但是你可以任意選擇答案輸出的順序。

思路:參考leetcode題解,利用回溯,這題類似於leetcode 46. 全排列,都可以運用 "前進 + 回退" 的回溯法實現

(另外,也可參考此題解:leetcode題解,包含回溯模板)

go版本:

// 回溯: 前進 + 回退

vectorlettercombinations(string digits) ;

vectorcombinations;

string combination;

dfs(digits, 0, combination, combinations);

return combinations;

}void dfs(string digits, int level, string combination, vector& combinations) // combinations加引用:每次復用該空間:否則每次回退時,會清理掉該空間,結果為空(若不加引用則要定義為函式外部的全域性變數)

for (int i = 0; i < m[digits[level]].size(); i++) // m[digits[level]].size():表示數字鍵對應字母串的長度,比如:2對應"abc"長度為3

go版本:

Leetcode17 電話號碼組合

leetcode17 號碼組合 給定乙個僅包含數字 2 9 的字串,返回所有它能表示的字母組合。給出數字到字母的對映如下 與 按鍵相同 注意 1 不對應任何字母。示例 輸入 23 輸出 ad ae af bd be bf cd ce cf 思路 大家都能想到,我每次從裡面選擇乙個數,然後把所有的可能...

leetcode 17 電話號碼的字母組合

題目描述 給定乙個僅包含數字2 9的字串,返回所有它能表示的字母組合。給出數字到字母的對映如下 與 按鍵相同 注意 1 不對應任何字母。示例 輸入 23 輸出 ad ae af bd be bf cd ce cf 實現 string num 10 class solution private tem...

LeetCode17電話號碼的字母組合

給定乙個僅包含數字2 9的字串,返回所有它能表示的字母組合。給出數字到字母的對映如下 與 按鍵相同 注意 1 不對應任何字母。示例 輸入 23 輸出 ad ae af bd be bf cd ce cf class solution def lettercombinations self,digit...