17. 电话号码的字母组合
题目描述
给定一个仅包含数字 2-9 的字符串,返回所有它能表示的字母组合。答案可以按 任意顺序 返回。
给出数字到字母的映射如下(与电话按键相同)。注意 1 不对应任何字母。
示例1:
输入:digits = “23”
输出:[“ad”,“ae”,“af”,“bd”,“be”,“bf”,“cd”,“ce”,“cf”]
示例2:
输入:digits = “”
输出:[]
提示:
- 0 <= digits.length <= 4
- digits[i] 是范围 [‘2’, ‘9’] 的一个数字。
题解
思路
- 首先要定义一个查找表,记录数组2-9对应哪几个英文字母
- 之后进行回溯查找
代码
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
class Solution {
Map<Character, String> map;
List<String> res;
StringBuilder sb;
public List<String> letterCombinations(String digits) {
map = new HashMap<>();
res = new ArrayList<>();
sb = new StringBuilder();
if (digits == null || digits.length() == 0) {
return res;
}
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");
backTracking(0, digits);
return res;
}
public void backTracking(int startIndex, String digits) {
if(sb.length() == digits.length()) {
res.add(sb.toString());
return;
}
String s = map.get(digits.charAt(startIndex));
for(int j = 0; j < s.length(); j++) {
sb.append(s.charAt(j));
backTracking(startIndex + 1, digits);
sb.deleteCharAt(sb.length() - 1);
}
}
}