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

相关推荐
NE_STOP3 分钟前
vibe Coding -- 小项目实战
java
刘马想放假5 小时前
Modbus 全栈技术解析:TCP、RTU、ASCII、RTU over TCP
数据结构·网络协议
未秃头的程序猿6 小时前
Java 26正式发布!这3个新特性,让代码量直接减半
java·后端·面试
用户298698530146 小时前
Word 文档文本查找与替换的 Java 实现方案
java·后端
阿哉6 小时前
Nacos 服务发现源码:藏在背后的两套事件机制,90%的人只讲了一半
java
05Kevin6 小时前
lk每日冒险题--数据结构6.27
算法
咖啡八杯7 小时前
GoF设计模式——命令模式
java·设计模式·架构
AI人工智能_电脑小能手7 小时前
【大白话说Java面试题 第125题】【并发篇】第25题:说说 Java 线程的中断机制
java·后端·面试
Java内核笔记7 小时前
Spring Security 源码解析(六)无状态 JWT 实践:Session 共享与自定义过滤器
java·后端