【算法hot-17】电话号码的字母组合
算法 17 hot 电话号码
2023-09-27 14:29:28 时间
电话号码的字母组合
给定一个仅包含数字 2-9 的字符串,返回所有它能表示的字母组合。答案可以按 任意顺序 返回。
给出数字到字母的映射如下(与电话按键相同)。注意 1 不对应任何字母。
public class LC006_17_letterCombinations {
public static void main(String[] args) {
List<String> ans = letterCombinations("23");
System.out.println(ans.size());
for (String string : ans) {
System.out.println(string + " ");
}
}
public static List<String> letterCombinations(String digits) {
//特殊情况
if (digits == null || digits.length() == 0) {
return new ArrayList<>();
}
String[] letter_map = {" ", "*", "abc", "def", "ghi", "jkl", "mno", "pqrs", "tuv", "wxyz"};
List<String> ans = new ArrayList<>();
ans.add("");
//遍历字符串的长度
for (int i = 0; i < digits.length(); i++) {
//遍历ans的长度
int size = ans.size();
for (int j = 0; j < size; j++) {
String temp = ans.remove(0);
//获取当前的字符串
String s = letter_map[digits.charAt(i) - '0'];
//遍历当前字符串的长度
for (int k = 0; k < s.length(); k++) {
ans.add(temp + s.charAt(k));
}
}
}
return ans;
}
}
相关文章
- 产业级目标检测算法全解读
- 【频谱共享】基于认知无线电的VCG拍卖机制频谱共享算法的MATLAB仿真
- 多目标PSO优化算法的仿真
- 基于sift变换的图片拼接算法的研究
- 机器学习面试题——聚类算法
- 深入浅出的排序算法-选择排序
- Memcached 笔记与总结(6)PHP 实现 Memcached 的一致性哈希分布算法
- QMap QHash的选择(QString这种复杂的比较,哈希算法比map快很多)
- 最小生成树(二)Prim算法
- 116、【回溯算法】leetcode ——17. 电话号码的字母组合:回溯法:哈希映射+字符串数组映射(C++版本)
- 贪心优先搜索算法与A*算法python实现
- KMP算法具体解释(转)
- 算法帖——用舞蹈链算法(Dancing Links)求解俄罗斯方块覆盖问题