17. 电话号码的字母组合

给定一个仅包含数字 2-9 的字符串,返回所有它能表示的字母组合。

给出数字到字母的映射如下(与电话按键相同)。注意 1 不对应任何字母。

 

示例:

输入:"23"
输出:["ad", "ae", "af", "bd", "be", "bf", "cd", "ce", "cf"].
说明:
尽管上面的答案是按字典序排列的,但是你可以任意选择答案输出的顺序。

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/letter-combinations-of-a-phone-number
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

 1 public class Solution {
 2     private Map<Integer, char[]> map = null;
 3     private char[] digits = null;
 4 
 5     private List<String> helper(int cur){
 6         List<String> res = new ArrayList<>();
 7         if (cur == 0) {
 8             char[] value = map.get(digits[cur]-'0');
 9             for (char c : value) {
10                 res.add(c+"");
11             }
12             return res;
13         }
14         List<String> sub = helper(cur - 1);
15 
16         char[] value = map.get(digits[cur]-'0');
17         for (String s : sub) {
18             for (char c : value) {
19                 res.add(s+c);
20             }
21         }
22         return res;
23     }
24 
25     public List<String> letterCombinations(String digits) {
26         if (digits.equals("")) return new ArrayList<>();
27         int count, digit = 2;
28 
29         map = new HashMap<>();
30         this.digits = digits.toCharArray();
31 
32         for (char i = 'a'; i <= 'z';) {
33             count = (digit == 7 || digit == 9) ? 4 :3;
34             char[] value = new char[count];
35             for (int j = 0; j < count; j++) {
36                 value[j] = i++;
37             }
38             map.put(digit++, value);
39         }
40         return helper(digits.length()-1);
41     }
42 
43     public static void main(String[] args) {
44         List<String> list = new Solution().letterCombinations("");
45         for (String s : list) {
46             System.out.print(s+", ");
47         }
48     }
49 }

 

posted @ 2019-09-30 19:15  赤云封天  阅读(169)  评论(0编辑  收藏  举报