LeetCode:17电话号码的字母组合

java 复制代码
class Solution {

    List<String> res = new ArrayList<>();
    StringBuilder path = new StringBuilder();
    //手机按键映射表,0,1没有字母用空字符串占位
    String[] letterMap = {"", "", "abc", "def", "ghi", "jkl", "mno", "pqrs", "tuv", "wxyz"};
    
    public List<String> letterCombinations(String digits) {
        if(digits == null || digits.length() == 0){
            return res;
        }    
        backtrack(digits,0);
        return res;
    }
    //index代表当前正在处理的digits的第几个数字
    private void backtrack(String digits,int index){
        if(index == digits.length()){
            res.add(path.toString());
            return;
        }
        //取出数字字符
        char digitChar = digits.charAt(index);
        //将数字字符转换成数字
        int digit = digitChar - '0';
        //查找该数字对应的字母组合
        String letters = letterMap[digit];

        for(int i = 0; i < letters.length(); i++){
            path.append(letters.charAt(i));
            backtrack(digits, index + 1);
            path.deleteCharAt(path.length() - 1);
        }
    }
}

deleteCharAt(int index):删除位于指定下标处的那个字符

解题思路:

首先新建两个变量res和path,res用于盛放最终的结果集,path用于盛放单个的结果

然后定义一个字符数组,用于映射手机按键

定义一个回溯函数,当index与要求的digits的长度相等则将path放入到res中

取出digits的数字字符然后转成数字,并查找对应的字符组合

循环遍历,将字符添加到path中然后递归处理

最后将字符串长度-1

相关推荐
我是一颗柠檬1 小时前
【Java项目技术亮点】Outbox事件驱动模式:解决分布式事务的终极方案
java·开发语言·分布式·后端·中间件·kafka
醉颜凉1 小时前
Scala自定义Monad实战:从理论到应用的完整指南
大数据·算法·scala
_Evan_Yao1 小时前
为 LLM 预留“插座”:设计可插拔的 AI 能力底座
java·人工智能·后端·python
我登哥MVP1 小时前
Spring Boot 从“会用”到“精通”:Converter 原理
java·spring boot·servlet·maven·mybatis·converter
STY_fish_20121 小时前
KMP-前缀函数
算法
Clf丶忆笙1 小时前
搭建支持多语言开发的Quarkus环境:Java、Kotlin与Scala全栈指南
java·开发语言·云原生·kotlin·scala·quarkus
java1234_小锋1 小时前
LangChain4j 开发Java Agent智能体- 对话与提示词工程(Prompt)
java·开发语言·prompt·langchain4j
zzz_23681 小时前
【Redis】Redis 数据结构与 Spring Boot 集成
数据结构·spring boot·redis
feng_you_ying_li1 小时前
Linux 之线程封装,线程的同步与互斥,互斥锁的介绍
linux·c++·算法