当前位置: 首页 > news >正文

力扣17-电话号码的数字组合

力扣17-电话号码的数字组合

    • 思路
    • 代码

题目链接

思路

在这里插入图片描述
原题:
给定一个仅包含数字 2-9 的字符串,返回所有它能表示的字母组合。答案可以按 任意顺序 返回。

给出数字到字母的映射如下(与电话按键相同)。注意 1 不对应任何字母。
输入:digits = “23”
输出:[“ad”,“ae”,“af”,“bd”,“be”,“bf”,“cd”,“ce”,“cf”

思路:
电话号码中的一个数字可以对应到多个字母,例如2对应a、b、c。要求23对应的字母组合,就是把2和3对应的字母进行组合。
在每次组合的过程中,一个数字只能取一个字母,不能连续两个字母来自同一个数字;
思考:
问题1:如何收集一个可能的组合?
问题2:在收集到一种组合后,如何继续收集第二种组合?
对于问题1:用暴力法可以解决,每层循环枚举一个数字对应的字母,但是电话号码串很长,循环嵌套深,代码不易好编写
可以采用递归的方式,每层进入递归函数,尝试一个数字对应的点好号码
进入函数,可以想向成进入一棵树的下一层,当递归的深度到达电话号码长度,即到达叶子节点,则返回。
问题3:在递归的每一层做什么?
递归纵向是进入树下一层,即电话号码中的一个数字,在同一层,应该去枚举这个数字对应的字母,这样就可以将当前层的字母,与上一层的字母进行结合,形成答案的一部分,,
问题4:递归什么时候结束?
到达电话号码的长度时,应该往树的上一层返回。

这里的往下递,和往上归,即回溯法,往下遍历是搜索,往上是回溯;回退到上一层,当前数字对应的字母就丢弃了,
比如 2,3; 3是第二层,遍历得到的字母组合是ab, 已经达到电话号码长度,往上一层回溯时b应该就被丢弃。

因此,本题使用回溯法,纵向遍历电话号码中的每个数字,横向遍历每个数字对应的字母,达到电话号码长度时收集一种组合,并往上一层回溯。

代码

class Solution {private List<String> ans;private String[][] dic = {{"2","abc"},{"3","def"},{"4","ghi"},{"5","jkl"},{"6","mno"},{"7","pqrs"},{"8","tuv"},{"9","wxyz"}};public List<String> letterCombinations(String digits) {ans = new ArrayList<>();if (digits.length()==0) {return ans;}Map<String,String> m = new HashMap<>();for (int i=0, n=dic.length; i<n; i++) {m.put(dic[i][0]+"", dic[i][1]+"");}String path = "";dfs(digits, m, 0, path);return ans;}public void dfs(String digits, Map<String, String> mp, int i, String path) {int n = digits.length();if (i>=n) {ans.add(new String(path));return;}String t = mp.get(digits.charAt(i)+"");for (int j=0, m=t.length(); j<m; j++) {dfs(digits, mp, i+1, path+t.charAt(j));}}
}
http://www.lryc.cn/news/481201.html

相关文章:

  • 如何处理模型的过拟合和欠拟合问题
  • CSRF详解
  • C# winform 的数据采集,采集周期是间隔10ms、100ms等等,但始终都有1ms的误差,并不是精准的10ms,哪些原因呢
  • 【国内中间件厂商排名及四大中间件对比分析】
  • qt QLocale详解
  • Node.js简介以及安装部署 (基础介绍 一)
  • unity实习面
  • React Native WebView 进阶:实现带回调函数的通讯
  • 【设计模式】结构型模式(四):组合模式、享元模式
  • 分布式数据库中间件mycat
  • 放大电路中的反馈 > 负反馈 > 四种组态 > 虚断和虚短
  • STM32F405RGT6单片机原理图、PCB免费分享
  • 大语言模型鼻祖Transformer的模型架构和底层原理
  • GB/T 43206—2023信息安全技术信息系统密码应用测评要求(五)
  • 深度学习:BERT 详解
  • 智能的编织:C++中auto的编织艺术
  • 订单分库分表
  • 【温度表达转化】
  • 封装一个web Worker 处理方法实现多线程
  • unity3d————屏幕坐标,GUI坐标,世界坐标的基础注意点
  • MySQL基础-单表查询
  • Web安全之SQL注入---基础
  • MongoDB笔记03-MongoDB索引
  • Docker基础(一)
  • 解决 IntelliJ IDEA Maven 项目 JDK 版本自动变为 1.5 的问题
  • SDL事件相关
  • 探索App Intents:让你的应用与Siri无缝互动的新方式
  • 冒泡排序法
  • MATLAB 将fig格式另存为可编辑的eps格式,但乱码问题解决
  • Hadoop:单节点配置YARN