LeetCode:77. 组合

跟着carl学算法,本系列博客仅做个人记录,建议大家都去看carl本人的博客,写的真的很好的!
代码随想录
LeetCode: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]]

java 复制代码
	public List<List<Integer>> combine(int n, int k) {
        List<List<Integer>> res = new ArrayList<>();
        backtracking(n, k, 1, new ArrayList<>(), res);
        return res;
    }

    private void backtracking(int n, int k, int startIndex, List<Integer> path, List<List<Integer>> res) {
        if (path.size() == k) {
            // res.add(path);
            // 这里应该添加一个新的list而不是直接添加path!
            res.add(new ArrayList<>(path));
            return;
        }
        for (int i = startIndex; i <= (n - (k - path.size()) + 1); i++) {
            path.add(i);
            backtracking(n, k, i + 1, path, res);
            path.removeLast();
        }
    }
相关推荐
qianmoq2 分钟前
轻松掌握Java多线程 - 第二章:线程的生命周期
java·后端
风象南3 分钟前
Spring Boot 实现文件断点续传
java·spring boot·后端
Lecea_L9 分钟前
你能在K步内赚最多的钱吗?用Java解锁最大路径收益算法(含AI场景分析)
java·人工智能·算法
Tony8811 分钟前
热题100 - 394. 字符串解码
java·算法
cwtlw14 分钟前
JavaRedis和数据库相关面试题
java·数据库·笔记·面试
XF鸭15 分钟前
身份证正则表达式详解
java
Lecea_L16 分钟前
🔍 找到数组里的“节奏感”:最长等差子序列
java·算法
是Dream呀19 分钟前
ResNeXt: 通过聚合残差变换增强深度神经网络
人工智能·算法
JojO_o33 分钟前
frida 在安卓模拟器上的使用
java
kill bert38 分钟前
第32周Java微服务入门 微服务基础
java·开发语言·微服务