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

示例 1:
输入:digits = “23”
 输出:[“ad”,“ae”,“af”,“bd”,“be”,“bf”,“cd”,“ce”,“cf”]
 示例 2:
输入:digits = “”
 输出:[]
 示例 3:
输入:digits = “2”
 输出:[“a”,“b”,“c”]
思考
第一步 获取digits对应的各个按键数值并保存在ints数组中
第二步 构建映射字符串数组letter,每个按键对应几个字母
第三步 利用回溯法,获取所有结果
Step 1获取按键数值
      int[] ints=new int[digits.length()];
      for (int i = 0; i < digits.length(); i++) {
            ints[i] = (int) digits.charAt(i) - (int)('0');
        }
Step 2 创建映射字符串数组
 String[] letter = new String[]{"abc","def","ghi","jkl","mno","pqrs","tuv","wxyz"};
Step 3 回溯法
回溯法其实就是一个暴利搜索,都可以将问题转化为树状结构。
以digits= 23为例

这里s字符串充当临时栈
真实的按钮数值与映射字符串数组坐标差2
- int index = ints[startIndex]-2;
class Solution {
    String[] letter = new String[]{"abc","def","ghi","jkl","mno","pqrs","tuv","wxyz"};
    String s="";
    public List<String> letterCombinations(String digits) {
        List<String> list = new ArrayList<>();
        if(digits.equals("")) return list;
        int[] ints=new int[digits.length()];
        for (int i = 0; i < digits.length(); i++) {
            ints[i] = (int) digits.charAt(i) - (int)('0');
        }
        int startIndex = 0;
        backTracking(list,ints,startIndex);
        return list;
        
    }
    private void backTracking(List<String> list, int[] ints,int startIndex) {
        if(s.length() == ints.length){
            list.add(new String(s));
            return;
        }
        int index = ints[startIndex]-2;
        for (int j = 0; j < letter[index].length(); j++) {
            s = s + String.valueOf(letter[index].charAt(j));
            backTracking(list,ints,startIndex+1);
            s = s.substring(0,s.length()-1);
        }
    }
}










