LeetCode 17 電話號碼的字母組合

2022-06-10 08:24:06 字數 1161 閱讀 8760

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

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

示例:

輸入:"23"

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

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

回溯法:

維護乙個雜湊表,用來查詢數字對應的字母表;

維護乙個字串,初始化為空,每次取一位數字,並將該數字的其中乙個可能的字母插入到該字串中,直至取完所有數字,即可得到乙個解,將該解存入最終輸出的容器中;

回溯:回退一位數字,更新其可能的字母,回退至第一位,即遍歷所有情況。

在c++中採用unordered_map維護乙個雜湊表,unordered_mapmap的區別在於,unordered_map基於雜湊表,其查詢的時間複雜度為\(o(1)\),map基於紅黑樹,具有有序性,對於需要大量修改map中的內容時,map的時間複雜度為\(o(\log n)\)。

本例題中只需要查詢,用unordered_map

class solution ,,,

,,,,

};public:

vectorlettercombinations(string digits)

void backtrack(vector&combinations, string digits, int index, string &combination)

char digit = digits[index];

string letters = phonemap.at(digit);

for(auto letter : letters) }};

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...