每日一题 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);
        }
    }
}
相关推荐
ChaseDreamRunner10 分钟前
如何用 NSSM 把 Jar 做成 Windows 服务
java·windows·jar
神の愛11 分钟前
java的Aop
java·开发语言
励志的小陈22 分钟前
双指针算法--移除元素、删除有序数组中的重复项、合并两个有序数组
算法
左左右右左右摇晃23 分钟前
ConcurrentHashMap ——put + get
java·开发语言·笔记
啥咕啦呛35 分钟前
java打卡学习4:HashMap底层结构、扩容机制
java·学习·哈希算法
qq_2975746741 分钟前
K8s系列第十四篇:K8s 故障排查实战:常见故障定位与解决方法
java·docker·kubernetes
Flittly41 分钟前
【SpringAIAlibaba新手村系列】(3)ChatModel 与 ChatClient 的深度对比
java·人工智能·spring boot·spring
2401_835792541 小时前
Java复习上
java·开发语言·python
hoiii1871 小时前
Mean Shift目标跟踪算法MATLAB实现
算法·matlab·目标跟踪
alphaTao1 小时前
LeetCode 每日一题 2026/3/23-2026/3/29
服务器·windows·leetcode