题目需求:给定一个仅包含数字 2-9 的字符串,返回所有它能表示的字母组合。答案可以按 任意顺序 返回。
给出数字到字母的映射如下(与电话按键相同)。注意 1 不对应任何字母。

- 示例 1:
 输入:digits = “23”
 输出:[“ad”,”ae”,”af”,”bd”,”be”,”bf”,”cd”,”ce”,”cf”]
- 示例 2:
 输入:digits = “”
 输出:[]
- 示例 3:
 输入:digits = “2”
 输出:[“a”,”b”,”c”]
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 
 | class Solution {public List<String> letterCombinations(String digits) {
 List<String> combinations = new ArrayList<String>();
 if (digits.length() == 0) {
 return combinations;
 }
 Map<Character, String> phoneMap = new HashMap<Character, String>() {{
 put('2', "abc");
 put('3', "def");
 put('4', "ghi");
 put('5', "jkl");
 put('6', "mno");
 put('7', "pqrs");
 put('8', "tuv");
 put('9', "wxyz");
 }};
 backtrack(combinations, phoneMap, digits, 0, new StringBuffer());
 return combinations;
 }
 
 public void backtrack(List<String> combinations, Map<Character, String> phoneMap, String digits, int index, StringBuffer combination) {
 if (index == digits.length()) {
 combinations.add(combination.toString());
 } else {
 char digit = digits.charAt(index);
 String letters = phoneMap.get(digit);
 int lettersCount = letters.length();
 for (int i = 0; i < lettersCount; i++) {
 combination.append(letters.charAt(i));
 backtrack(combinations, phoneMap, digits, index + 1, combination);
 combination.deleteCharAt(index);
 }
 }
 }
 }
 
 | 
自己的理解是,使用回溯算法,通过建立一个哈希表,将每个数字对应的字母存储起来。然后进行回溯操作。具体就是
比如:2 -> [a,b,c] -> 3 -> [d,e,f] => [ad,ae,af,bd,be,bf,cd,ce,cf]
每次取电话号码的一位数字,从哈希表中获得该数字对应的所有可能的字母,并将其中的一个字母插入到已有的字母排列后面,然后继续处理电话号码的后一位数字,直到处理完电话号码中的所有数字,即得到一个完整的字母排列。