No.17 Letter Combinations of a Phone Number

17. 电话号码的字母组合 - 力扣(LeetCode) (leetcode-cn.com)

 

思路:一道普通的用回溯解决的组合问题,涉及到一些字符串的操作

          用一个map_string存储,用下标的索引表示数字对应的字母

package leetcode.com.backTrack;

import java.util.ArrayList;
import java.util.List;

public class Num17 {
    public static void main(String[] args) {
        Num17 tool = new Num17();
        List<String> res = tool.letterCombinations("234");
        for(String arr:res){
            System.out.println(arr);
        }
    }

    public List<String> letterCombinations(String digits) {
        List<String> ans = new ArrayList<>();
        if(digits=="" || digits.length()==1){
            return ans;
        }
        String[] map_string = {"", "*", "abc", "def", "ghi", "jkl", "mno", "pqrs", "tuv", "wxyz"};
        StringBuffer path = new StringBuffer();
        backtrack(digits, 0, path, ans, map_string);
        return ans;
    }

    public void backtrack(String digits, int index, StringBuffer path, List<String> ans,
                          String[] map_string){
        /**
         * digits 表示输入的数字, eg: digits="23"
         * path存放字符串, 长度够了就加入 List<String> ans
         * letter 表示当前层可以选择的数字,eg: 第一层数字为2, 可选 letter=“abc"
         * index 表示选择当前层的哪一个digits中的数字
         * ans用来存储答案
         */
        if(index == digits.length()){
            ans.add(path.toString());
            return;
        }
        char tmpWord =  digits.charAt(index);
        int letterIdx = tmpWord - '0';
        String letter = map_string[letterIdx];
        for(int i=0; i<letter.length(); i++){
            path.append(letter.charAt(i));
            backtrack(digits, index+1, path, ans, map_string);
            path.deleteCharAt(path.length()-1);   // 这个地方不是删除 i , 我感觉删除i就是删除末尾的,但是不对,得直接删除当前末尾的
        }
    }
}

。。。

上一篇:值周 (区间合并 差分


下一篇:Markdown样式