电话号码的字母组合
给定一个仅包含数字 2-9 的字符串,返回所有它能表示的字母组合。答案可以按 任意顺序 返回。
给出数字到字母的映射如下(与电话按键相同)。注意 1 不对应任何字母。
示例
输入: digits = “23”
输出:[“ad”,“ae”,“af”,“bd”,“be”,“bf”,“cd”,“ce”,“cf”]
解题思路
- 1、使用回溯算法来生成所有可能的字母组合。
- 2、对于每个数字,根据其对应的字母集合,依次选择一个字母,然后递归生成下一个数字对应的字母组合。
- 3、使用回溯算法来探索所有可能的选择。
Java实现
public class LetterCombinations {
private static final Map<Character, String> digitToLetters = new HashMap<>();
static {
digitToLetters.put('2', "abc");
digitToLetters.put('3', "def");
digitToLetters.put('4', "ghi");
digitToLetters<