给定一个仅包含数字 2-9 的字符串,返回所有它能表示的字母组合。
给出数字到字母的映射如下(与电话按键相同)。注意 1 不对应任何字母。
示例:
输入:“23”
输出:[“ad”, “ae”, “af”, “bd”, “be”, “bf”, “cd”, “ce”, “cf”].
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/letter-combinations-of-a-phone-number
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
代码:
class Solution {
public Map<String,String> phone = new HashMap<String, String>(){
{
put("2", "abc");
put("3", "def");
put("4", "ghi");
put("5", "jkl");
put("6", "mno");
put("7", "pqrs");
put("8", "tuv");
put("9", "wxyz");
}
};
public void backtrack(String combineStr, String nextdigits,List<String> output){
if(nextdigits.length() == 0){
output.add(combineStr);
}else{
//取该字符串第一个数字
String digit = nextdigits.substring(0,1);
//获取这个数字代表的字符串
String letters = phone.get(digit);
//遍历字符串
for(int i=0;i<letters.length();i++){
String letter = letters.substring(i, i + 1);
//开始下一轮递归前把数字字符串改变
String nextdig = nextdigits.substring(1);
//递归
backtrack(combineStr+letter,nextdig,output);
}
}
}
public List<String> letterCombinations(String digits) {
String temp = "";
List<String> output = new ArrayList<String>();
if(digits.equals("")){
return output;
}
backtrack(temp,digits,output);
return output;
}
}