回溯法
class Solution {
public List<String> letterCombinations(String digits) {
List<String> ans = new ArrayList<>();
if(digits.length() == 0)
return ans;
String[] strs = {"abc", "def", "ghi", "jkl", "mno", "pqrs", "tuv", "wxyz"};
backTrace(ans, strs, digits, 0, new StringBuilder());
return ans;
}
public void backTrace(List<String> ans, String[] strs, String digits, int index, StringBuilder sb){
if(index == digits.length()){
ans.add(sb.toString());
return;
}
int t = digits.charAt(index) - '2';
String str = strs[t];
for(int i = 0;i < str.length();i++){
sb.append(str.charAt(i));
backTrace(ans, strs, digits, index+1, sb);
sb.deleteCharAt(index);
}
}
}