力扣经典算法篇-38-组合(回溯算法)

1、题干

给定两个整数 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

2、解题

方法一:(回溯算法)

这是一道类似全排列的问题,给定范围,给出要求,求出可能得所有组合,可以使用回溯算法求解。
回溯算法要点:

明确不变的量,明确本趟组装的临时变量,明确结果集合。递归处理;

递归的终止条件(一般是临时变量符合要求),添加结果集;非终止的情况下循环处理,先添加元素向后发起,之后在删除元素向前回溯。

套用上面的公式,代码示例如下。

代码示例:

java 复制代码
public static List<List<Integer>> combine(int n, int k) {
        List<List<Integer>> result = new ArrayList<>();   // 结果集

        List<Integer> tempList = new ArrayList<>();   // 当前趟的组合
        int index = 1;    // 添加元素的位置
        goAndBack(n, k, tempList, index, result);    // 固定部分(n,k),临时可变部分(tempList,index),结果集(result)
        return result;
    }

    private static void goAndBack(int n, int k, List<Integer> tempList, int index, List<List<Integer>> result) {
        if (tempList.size() == k) {   // 递归终止条件
            result.add(new ArrayList<>(tempList));     // 注意tempList需要删除元素进行回溯处理,所用new ArrayList<>包裹处理。
            return;
        }

        for (int i = index; i <= n; i++) {        // 使用index为起始位置,防止添加相同的元素。
            // 临时部分处理后,递归向后处理
            tempList.add(i);   // 临时部分tempList添加元素
            goAndBack(n, k, tempList, i + 1, result);    // 下一个元素位置index从之后的i+1开始,防止添加重复元素 
            // 删除元素,回溯处理。删除最后的元素
            tempList.remove(tempList.size() - 1);
        }
    }

向阳前行,Dare To Be!!!

相关推荐
故事和你912 小时前
洛谷-数据结构1-1-线性表1
开发语言·数据结构·c++·算法·leetcode·动态规划·图论
脱氧核糖核酸__2 小时前
LeetCode热题100——53.最大子数组和(题解+答案+要点)
数据结构·c++·算法·leetcode
脱氧核糖核酸__3 小时前
LeetCode 热题100——42.接雨水(题目+题解+答案)
数据结构·c++·算法·leetcode
王老师青少年编程4 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【线性扫描贪心】:数列分段 Section I
c++·算法·编程·贪心·csp·信奥赛·线性扫描贪心
王老师青少年编程4 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【线性扫描贪心】:分糖果
c++·算法·贪心算法·csp·信奥赛·线性扫描贪心·分糖果
_日拱一卒4 小时前
LeetCode:2两数相加
算法·leetcode·职场和发展
py有趣4 小时前
力扣热门100题之零钱兑换
算法·leetcode
董董灿是个攻城狮4 小时前
Opus 4.7 来了,我并不建议你升级
算法
无敌昊哥战神4 小时前
【保姆级题解】力扣17. 电话号码的字母组合 (回溯算法经典入门) | Python/C/C++多语言详解
c语言·c++·python·算法·leetcode
脱氧核糖核酸__4 小时前
LeetCode热题100——238.除了自身以外数组的乘积(题目+题解+答案)
数据结构·c++·算法·leetcode