代码随想录训练营二刷第二十五天 | 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);
        }
    }
}
相关推荐
你撅嘴真丑1 小时前
第九章-数字三角形
算法
uesowys1 小时前
Apache Spark算法开发指导-One-vs-Rest classifier
人工智能·算法·spark
ValhallaCoder1 小时前
hot100-二叉树I
数据结构·python·算法·二叉树
董董灿是个攻城狮1 小时前
AI 视觉连载1:像素
算法
智驱力人工智能2 小时前
小区高空抛物AI实时预警方案 筑牢社区头顶安全的实践 高空抛物检测 高空抛物监控安装教程 高空抛物误报率优化方案 高空抛物监控案例分享
人工智能·深度学习·opencv·算法·安全·yolo·边缘计算
孞㐑¥3 小时前
算法——BFS
开发语言·c++·经验分享·笔记·算法
月挽清风3 小时前
代码随想录第十五天
数据结构·算法·leetcode
XX風3 小时前
8.1 PFH&&FPFH
图像处理·算法
NEXT063 小时前
前端算法:从 O(n²) 到 O(n),列表转树的极致优化
前端·数据结构·算法
代码游侠4 小时前
学习笔记——设备树基础
linux·运维·开发语言·单片机·算法