每日一题 77组合(剪枝)

题目

77

给定两个整数 n 和 k,返回范围 [1, n] 中所有可能的 k 个数的组合。

你可以按 任何顺序 返回答案。

示例 1:

输入:n = 4, k = 2

输出:

\[2,4\], \[3,4\], \[2,3\], \[1,2\], \[1,3\], \[1,4\],

示例 2:

输入:n = 1, k = 1

输出:[[1]]

提示:

1 <= n <= 20

1 <= k <= n

题解

选或不选

java 复制代码
class Solution {
    private List<Integer> path = new ArrayList<>();
    private List<List<Integer>> ans = new ArrayList<>();
    private int k;
    public List<List<Integer>> combine(int n, int k) {
        this.k = k;
        dfs(n);
        return ans;
    }
    private void dfs(int i) {
        //可以选的个数
        int d = k - path.size();
        if (d == 0) {
            ans.add(new ArrayList<>(path));
            return;
        }
        if (i > d) {
            dfs(i - 1);
        }
        path.add(i);
        dfs(i - 1);
        path.remove(path.size() - 1);
    }
}

答案视角

java 复制代码
class Solution {
    private List<Integer> path = new ArrayList<>();
    private List<List<Integer>> ans = new ArrayList<>();
    private int k;
    public List<List<Integer>> combine(int n, int k) {
        this.k = k;
        dfs(n);
        return ans;
    }
    private void dfs(int i) {
        int d = k - path.size();
        if (d == 0) {
            ans.add(new ArrayList<>(path));
            return;
        }
        for (int j = i; j >= d; j--) {
            path.add(j);
            dfs(j - 1);
            path.remove(path.size() - 1);
        }
    }
}
相关推荐
杉之15 分钟前
Java中的不可变集合
java·笔记·学习
舔甜歌姬的EGUMI LEGACY18 分钟前
【算法day28】解数独——编写一个程序,通过填充空格来解决数独问题
算法
潘多编程18 分钟前
Gradle实战指南:从入门到进阶,与Maven的深度对比
java·maven
故城、20 分钟前
MQ中的RabbitMQ
java·mq
深圳厨神22 分钟前
浅谈数据结构
数据结构
JCBP_23 分钟前
数据结构4
运维·c语言·数据结构·vscode
welkin31 分钟前
KMP 个人理解
前端·算法
橘猫云计算机设计36 分钟前
基于JavaWeb的二手图书交易系统(源码+lw+部署文档+讲解),源码可白嫖!
java·开发语言·前端·毕业设计·php
猿java36 分钟前
程序员,你使用过灰度发布吗?
java·分布式·后端
半桔37 分钟前
红黑树剖析
c语言·开发语言·数据结构·c++·后端·算法