Description

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

示例 1:

  1. 输入:digits = "23"
  2. 输出:["ad","ae","af","bd","be","bf","cd","ce","cf"]

示例 2:

输入:digits = ""
输出:[]

示例 3:

输入:digits = "2"
输出:["a","b","c"]

提示:

  • 0 <= digits.length <= 4
  • digits[i] 是范围 ['2', '9'] 的一个数字。

Solution

回溯加哈希表

class Solution {
    public Map<Integer, String> map;
    {
        map = new HashMap<>();
        map.put(2, "abc");      
        map.put(3, "def");      
        map.put(4, "ghi");      
        map.put(5, "jkl");      
        map.put(6, "mno");      
        map.put(7, "pqrs");      
        map.put(8, "tuv");      
        map.put(9, "wxyz");      
    }
    List<String> res;
    public List<String> letterCombinations(String digits) {
        res = new ArrayList<>();
        if (digits.length() == 0)
            return res;
        StringBuilder sbuilder = new StringBuilder();
        combinate(digits, 0, sbuilder);
        return res;
    }
    // 回溯,遍历所有的可能
    private void combinate(String digits, int index, StringBuilder sbuilder){
        if (sbuilder.length() == digits.length()){
            this.res.add(sbuilder.toString());
            return ;
        }
        String letters = this.map.get(digits.charAt(index)-'0');
        for (int i = 0; i < letters.length(); i ++){
            sbuilder.append(letters.charAt(i));
            combinate(digits, index+1,sbuilder);
            sbuilder.deleteCharAt(sbuilder.length()-1);
        }
    }
}