news 2026/4/13 16:20:31

电话号码的字母组合

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
电话号码的字母组合

给定一个仅包含数字2-9的字符串,返回所有它能表示的字母组合。答案可以按任意顺序返回。

给出数字到字母的映射如下(与电话按键相同)。注意 1 不对应任何字母。

示例 1:

输入:digits = "23"输出:["ad","ae","af","bd","be","bf","cd","ce","cf"]

关键点:

定义字符和字母的映射 '2' -> "abc"

用stringBuilder拼接递归中字母

递归中对每个按键可取字母进行遍历(穷举的过程),遍历一轮要把上轮已拼接好的删除掉,穷举拼接上新的字符

中止条件就是当前索引 == 字符串的长度

public List<String> letterCombinations(String digits) { List<String> combinations = new ArrayList<>(); if (digits.length() == 0) { return combinations; } // 初始化map Map<Character, String> photoMap = new HashMap<Character, 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"); }}; letterCombinationsDfs(digits, 0, new StringBuilder(), combinations, photoMap); return combinations; } public void letterCombinationsDfs(String digits, int index, StringBuilder combination, List<String> combinations, Map<Character, String> photoMap) { if (index == digits.length()) { combinations.add(combination.toString()); } else { char digit = digits.charAt(index); String letters = photoMap.get(digit); int lettersCount = letters.length(); // 第一个字母开始进行递归 for (int i = 0; i < lettersCount; i++) { combination.append(letters.charAt(i)); // 每一个字母进行递归,进行下一个字母的递归 letterCombinationsDfs(digits, index + 1, combination, combinations, photoMap); // 删除当前字母 combination.deleteCharAt(index); } } }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/8 8:28:59

Windows Defender完全卸载实战:3种方案彻底解决系统防护困扰

Windows Defender完全卸载实战&#xff1a;3种方案彻底解决系统防护困扰 【免费下载链接】windows-defender-remover A tool which is uses to remove Windows Defender in Windows 8.x, Windows 10 (every version) and Windows 11. 项目地址: https://gitcode.com/gh_mirro…

作者头像 李华
网站建设 2026/4/8 22:54:39

鸣潮自动化工具技术解析:从原理到实战的完整指南

鸣潮自动化工具技术解析&#xff1a;从原理到实战的完整指南 【免费下载链接】ok-wuthering-waves 鸣潮 后台自动战斗 自动刷声骸上锁合成 自动肉鸽 Automation for Wuthering Waves 项目地址: https://gitcode.com/GitHub_Trending/ok/ok-wuthering-waves 您是否正在为…

作者头像 李华
网站建设 2026/4/13 10:16:53

AEUX动效神器:从静态设计到流畅动画的智能桥梁

AEUX动效神器&#xff1a;从静态设计到流畅动画的智能桥梁 【免费下载链接】AEUX Editable After Effects layers from Sketch artboards 项目地址: https://gitcode.com/gh_mirrors/ae/AEUX 告别重复的手动重建&#xff0c;AEUX插件正在重新定义设计师的工作流程。这款…

作者头像 李华
网站建设 2026/4/13 14:12:23

WaveTools鸣潮工具箱终极指南:从新手到高手的完整使用手册

WaveTools鸣潮工具箱终极指南&#xff1a;从新手到高手的完整使用手册 【免费下载链接】WaveTools &#x1f9f0;鸣潮工具箱 项目地址: https://gitcode.com/gh_mirrors/wa/WaveTools 还在为《鸣潮》游戏卡顿而烦恼&#xff1f;想要轻松解锁120帧极致体验&#xff1f;Wa…

作者头像 李华
网站建设 2026/4/11 11:19:57

数字孪生应用:Z-Image-Turbo生成设备可视化示意图

数字孪生应用&#xff1a;Z-Image-Turbo生成设备可视化示意图 引言&#xff1a;AI图像生成赋能数字孪生系统建设 在工业数字化转型加速的背景下&#xff0c;数字孪生&#xff08;Digital Twin&#xff09;技术正从概念走向大规模落地。其核心在于通过虚拟模型实时映射物理设备的…

作者头像 李华
网站建设 2026/4/6 8:42:27

3dsconv:3DS游戏格式转换的完整使用指南

3dsconv&#xff1a;3DS游戏格式转换的完整使用指南 【免费下载链接】3dsconv Python script to convert Nintendo 3DS CCI (".cci", ".3ds") files to the CIA format 项目地址: https://gitcode.com/gh_mirrors/3d/3dsconv 3dsconv是一款专为任天…

作者头像 李华