代码随想录训练营二刷第二十五天 | 216.组合总和III 17.电话号码的字母组合

代码随想录训练营二刷第二十五天 | 216.组合总和III 17.电话号码的字母组合

一、216.组合总和III

题目链接:https://leetcode.cn/problems/combination-sum-iii/

思路:模板题

java 复制代码
class Solution {
    List<List<Integer>> arrayList = new ArrayList<>();
    List<Integer> list = new ArrayList<>();
    int sum = 0;
    public List<List<Integer>> combinationSum3(int k, int n) {
        backTracking(k, n, 1);
        return arrayList;
    }
    void backTracking(int k, int n, int index) {
        if (list.size() < k && sum > n) return;
        if (list.size() == k && sum == n) {
            arrayList.add(new ArrayList<>(list));
            return;
        }
        for (int i = index; i <= 9; i++) {
            list.add(i);
            sum += i;
            backTracking(k, n, i+1);
            list.remove(list.size()-1);
            sum -= i;
        }
    }
}

二、17.电话号码的字母组合

题目链接:https://leetcode.cn/problems/letter-combinations-of-a-phone-number/

思路:每次递归选取的集合需要改变

java 复制代码
class Solution {
    List<String> list = new ArrayList<>();
    StringBuilder builder = new StringBuilder();
    public List<String> letterCombinations(String digits) {
        if (digits.length() == 0) return list;
        String[] init = {"", "", "abc", "def", "ghi", "jkl", "mno", "pqrs", "tuv", "wxyz"};
        String[] strList = new String[digits.length()];
        for (int i = 0; i < digits.length(); i++) {
            strList[i] = init[digits.charAt(i) - '0'];
        }
        backTracking(strList, 0);
        return list;
    }
    void backTracking(String[] strList, int index) {
        if (builder.length() == strList.length) {
            list.add(builder.toString());
            return;
        }
        String strings = strList[index];
        for (int i = 0; i < strings.length(); i++) {
            builder.append(strings.charAt(i));
            backTracking(strList, index + 1);
            builder.deleteCharAt(index);
        }
    }
}
相关推荐
CoovallyAIHub5 小时前
港大&字节重磅发布DanceGRPO:突破视觉生成RLHF瓶颈,多项任务性能提升超180%!
深度学习·算法·计算机视觉
CoovallyAIHub5 小时前
英伟达ViPE重磅发布!解决3D感知难题,SLAM+深度学习完美融合(附带数据集下载地址)
深度学习·算法·计算机视觉
聚客AI1 天前
🙋‍♀️Transformer训练与推理全流程:从输入处理到输出生成
人工智能·算法·llm
大怪v1 天前
前端:人工智能?我也会啊!来个花活,😎😎😎“自动驾驶”整起!
前端·javascript·算法
惯导马工1 天前
【论文导读】ORB-SLAM3:An Accurate Open-Source Library for Visual, Visual-Inertial and
深度学习·算法
骑自行车的码农1 天前
【React用到的一些算法】游标和栈
算法·react.js
博笙困了1 天前
AcWing学习——双指针算法
c++·算法
moonlifesudo1 天前
322:零钱兑换(三种方法)
算法
NAGNIP2 天前
大模型框架性能优化策略:延迟、吞吐量与成本权衡
算法
美团技术团队2 天前
LongCat-Flash:如何使用 SGLang 部署美团 Agentic 模型
人工智能·算法