二刷hot100-17.电话号码的字母组合

思路不难,过程有点繁琐

要预定义一个字符串数组,下标数字与对应元素字符串有着题目所示的映射规律;所以数组的0和1下标对应元素为" ";

这里使用string builder;

递归函数传入一个指针,代表当前过程字符串的长度,

终止条件:当长度与要求长度一致,收割结果

每次进入循环之前都要获取到当前指针所指数字对应的字符串;

以该字符串长度进行循环,每次循环将当前字符串加入中间结果

java 复制代码
class Solution {
    List<String> res = new ArrayList<>();
    public List<String> letterCombinations(String digits) {
        if(digits == null || digits.length() == 0){
            return res;
        }
        String[] numstring = {"","","abc","def","ghi","jkl","mno","pqrs","tuv","wxyz"};
        f(digits,numstring,0);
        return res;
    }
    StringBuilder temp = new StringBuilder();
    public void f(String digits,String[] numstring,int index){
        if(index == digits.length()){
            res.add(temp.toString());
            return;
        }
        String s = numstring[digits.charAt(index) - '0'];
        for(int i = 0;i < s.length();i++){
            temp.append(s.charAt(i));
            f(digits,numstring,index + 1);
            temp.deleteCharAt(temp.length() - 1);
        }
    }
}
相关推荐
想要成为糕糕手2 小时前
前端必修课:JavaScript 数组与数据结构底层逻辑全解析
javascript·数据结构·面试
tyung4 小时前
Go 手写 Wait-Free SPSC 无界队列:无 CAS、无锁、泛型节点池
数据结构·后端·go
Chen_harmony4 小时前
一、数据结构概念和复杂度计算
数据结构
小欣加油5 小时前
leetcode287寻找重复数
数据结构·c++·算法·leetcode
fie88897 小时前
LBP + HOG 特征检测与识别 MATLAB 实现
数据结构·算法·matlab
退休倒计时8 小时前
【每日一题】LeetCode 15. 三数之和 TypeScript
数据结构·算法·leetcode·typescript
AbandonForce8 小时前
滑动窗口:定长滑动窗口与不定长滑动窗口
数据结构·c++·算法
炸薯条!9 小时前
二叉树的链式表示(2)
java·数据结构·算法
YHHLAI9 小时前
JavaScript 数据结构精讲:数组底层与实战避坑
开发语言·javascript·数据结构
Coder-magician9 小时前
《代码随想录》刷题打卡day12:二叉树part02
数据结构·c++·算法