代码随想录训练营二刷第二十五天 | 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);
        }
    }
}
相关推荐
_深海凉_2 分钟前
LeetCode热题100-有效的括号
linux·算法·leetcode
被开发耽误的大厨3 小时前
1、==、equals、hashCode底层原理?重写场景?
算法·哈希算法
WolfGang0073213 小时前
代码随想录算法训练营 Day38 | 动态规划 part11
算法·动态规划
松☆4 小时前
C++ 算法竞赛题解:P13569 [CCPC 2024 重庆站] osu!mania —— 浮点数精度陷阱与 `eps` 的深度解析
开发语言·c++·算法
jr-create(•̀⌄•́)5 小时前
正则化和优化算法区别
pytorch·深度学习·神经网络·算法
li星野6 小时前
刷题:数组
数据结构·算法
tankeven6 小时前
HJ182 画展布置
c++·算法
CS_Zero8 小时前
无人机路径规划算法——EGO-planner建模总结—— EGO-planner 论文笔记(一)
论文阅读·算法·无人机
杰梵8 小时前
聚酯切片DSC热分析应用报告
人工智能·算法