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

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

题目描述

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

给出数字到字母的映射如下(与电话按键相同)。注意 1 不对应任何字母。
在这里插入图片描述

class Solution {List<String> res = new ArrayList<>();String[] letterMap = {"", "", "abc", "def", "ghi", "jkl", "mno", "pqrs", "tuv", "wxyz"};StringBuffer path = new StringBuffer();void backtracking(String digits, int index) { //如digits是"23",index是0if (digits.length() == path.length()) {res.add(path.toString());return;}int num = digits.charAt(index) - '0';String str = letterMap[num];	//如str是"abc"for (int i = 0; i < str.length(); i++) {path.append(str.charAt(i));backtracking(digits, index + 1);path.delete(path.length()-1, path.length());}}public List<String> letterCombinations(String digits) {if(digits.length()==0)return res;backtracking(digits, 0);return res;}
}

小结:中断了好多天回归刷题,这道题需要注意的是Java的String和数组的API与C++有很多不同,比如"23"找到2对应的"abc"和3对应的"def",之后套用回溯的模板,注意index是什么,i是什么,不要弄乱。

http://www.lryc.cn/news/2404570.html

相关文章:

  • 基于SpringBoot解决RabbitMQ消息丢失问题
  • 免费插件集-illustrator插件-Ai插件-随机填色
  • 使用 Unstructured 开源库快速入门指南
  • 白银6月想法
  • OpenCV 滑动条调整图像对比度和亮度
  • 船舶事故海上搜救VR情景演练全场景 “复刻”,沉浸式救援体验​
  • 使用Caddy在Ubuntu 22.04上配置HTTPS反向代理
  • 无人机目标检测与语义分割数据集(猫脸码客)
  • Web设计之登录网页源码分享,PHP数据库连接,可一键运行!
  • Cursor + Claude 4:微信小程序流量主变现开发实战案例
  • ㊗️高考加油
  • Redis Key过期策略
  • 【C/C++】实现固定地址函数调用
  • 多模态大语言模型arxiv论文略读(109)
  • 性能优化笔记
  • bat批量去掉本文件夹中的文件扩展名
  • 基于ROS2,撰写python脚本,根据给定的舵-桨动力学模型实现动力学更新
  • Scrapy爬虫教程(新手)
  • 数据可视化大屏案例落地实战指南:捷码平台7天交付方法论
  • 第五篇:Go 并发模型全解析——Channel、Goroutine
  • 锁的艺术:深入浅出讲解乐观锁与悲观锁
  • 在网页加载时自动运行js的方法(2025最新)
  • 在Windows下编译出llama_cpp_python的DLL后,在虚拟环境中使用方法
  • CSS radial-gradient函数详解
  • n8n 自动化平台 Docker 部署教程(附 PostgreSQL 与更新指南)
  • 关于datetime获取时间的问题
  • 前端面试五之vue2基础
  • 使用python实现奔跑的线条效果
  • Oracle 审计参数:AUDIT_TRAIL 和 AUDIT_SYS_OPERATIONS
  • Android LinearLayout、FrameLayout、RelativeLayout、ConstraintLayout大混战