news 2026/6/15 17:14:05

电话号码的字母组合

作者头像

张小明

前端开发工程师

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/6/15 14:58:03

Kodi字幕库插件终极使用教程:一键解决观影字幕烦恼

Kodi字幕库插件终极使用教程&#xff1a;一键解决观影字幕烦恼 【免费下载链接】zimuku_for_kodi Kodi 插件&#xff0c;用于从「字幕库」网站下载字幕 项目地址: https://gitcode.com/gh_mirrors/zi/zimuku_for_kodi 还在为Kodi播放视频时找不到合适字幕而困扰吗&#…

作者头像 李华
网站建设 2026/6/15 13:48:28

MyTV-Android:让老旧电视焕发新生的智能直播解决方案

MyTV-Android&#xff1a;让老旧电视焕发新生的智能直播解决方案 【免费下载链接】mytv-android 使用Android原生开发的电视直播软件 项目地址: https://gitcode.com/gh_mirrors/my/mytv-android 在智能设备快速迭代的今天&#xff0c;许多家庭的老旧电视因为系统版本限…

作者头像 李华
网站建设 2026/6/3 12:14:24

MusicBee网易云歌词插件终极使用指南

MusicBee网易云歌词插件终极使用指南 【免费下载链接】MusicBee-NeteaseLyrics A plugin to retrieve lyrics from Netease Cloud Music for MusicBee. 项目地址: https://gitcode.com/gh_mirrors/mu/MusicBee-NeteaseLyrics 想要让MusicBee播放器拥有海量精准同步的歌词…

作者头像 李华
网站建设 2026/6/15 12:36:34

Windows屏幕标注工具ppInk:免费开源的专业级解决方案

Windows屏幕标注工具ppInk&#xff1a;免费开源的专业级解决方案 【免费下载链接】ppInk Fork from Gink 项目地址: https://gitcode.com/gh_mirrors/pp/ppInk 在数字化协作日益普及的今天&#xff0c;屏幕标注工具已成为教学演示、产品展示和远程会议中不可或缺的辅助工…

作者头像 李华
网站建设 2026/6/15 15:47:49

HMCL启动器:如何一站式解决Minecraft版本管理与模组兼容难题?

HMCL启动器&#xff1a;如何一站式解决Minecraft版本管理与模组兼容难题&#xff1f; 【免费下载链接】HMCL huanghongxun/HMCL: 是一个用于 Minecraft 的命令行启动器&#xff0c;可以用于启动和管理 Minecraft 游戏&#xff0c;支持多种 Minecraft 版本和游戏模式&#xff0c…

作者头像 李华