Description
难度:中等
给定一个仅包含数字 2-9 的字符串,返回所有它能表示的字母组合。答案可以按 任意顺序 返回。
给出数字到字母的映射如下(与电话按键相同)。注意 1 不对应任何字母。
示例 1:
输入:digits = "23"输出:["ad","ae","af","bd","be","bf","cd","ce","cf"]
示例 2:
输入:digits = ""
输出:[]
示例 3:
输入:digits = "2"
输出:["a","b","c"]
提示:
0 <= digits.length <= 4digits[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);
}
}
}
