力扣77. 组合(java 回溯法)

Problem: 77. 组合

文章目录

题目描述

思路

题目要求给出1-n中每k个数一组的所有组合,我们可以利用回溯,将其穷举出来,具体的:

1.以数字1-n为回溯的决策阶段 ,回溯的起始阶段为1

2.回溯函数的结束条件有两个:1.当决策路径 的长度等于k时,将当前的路径添加到结果集合中并返回;2.当决策阶段等于k+1 时返回(因为等于k+1时表示1-k阶段已经穷举 完毕)

3.回溯处理(递归决策树),在每个阶段恢复上一个阶段的状态

解题方法

1.定义二维结果集result

2.调用并编写回溯函数:

2.1当决策路径的长度k时,将当前的路径添加到结果集合中并返回;.当决策阶段等于k+1 时返回

2.2先不添加决策到决策路径的递归 ,再添加决策到决策路径的递归同时还原本决策阶段的决策状态

复杂度

时间复杂度:

O ( C n k ) O(C_n^k) O(Cnk)

空间复杂度:

O ( n + C n k ) O(n + C_n^k) O(n+Cnk)

Code

java 复制代码
class Solution {
    //Save the result
    private List<List<Integer>> result = new ArrayList<>();

    /**
     * Get the combination
     * @param n The range of number(1~n)
     * @param k Specifies how many numbers are in a combination
     * @return List<List<Integer>>
     */
    public List<List<Integer>> combine(int n, int k) {
        backtrack(n, k, 1, new ArrayList<Integer>());
        return result;
    }

    /**
     * Backtracking fetch combination
     * @param n The range of number(1~n)
     * @param k Specifies how many numbers are in a combination
     * @param step Decision stage
     * @param path Decision path
     */
    public void backtrack(int n, int k, int step, List<Integer> path) {
        //End condition
        if (path.size() == k) {
            result.add(new ArrayList<>(path));
            return;
        }
        //End condition
        if (step == n + 1) {
            return;
        }
        backtrack(n, k, step + 1, path);
        path.add(step);
        backtrack(n, k, step + 1, path);
        path.remove(path.size() - 1);
    }
}
相关推荐
QWQ___qwq10 分钟前
Java线程安全深度总结:基本类型与引用类型的本质区别
java·安全·面试
识君啊37 分钟前
Java异常处理:中小厂面试通关指南
java·开发语言·面试·异常处理·exception·中小厂
qyzm2 小时前
天梯赛练习(3月13日)
开发语言·数据结构·python·算法·贪心算法
月月玩代码2 小时前
Actuator,Spring Boot应用监控与管理端点!
java·spring boot·后端
逆境不可逃2 小时前
LeetCode 热题 100 之 64. 最小路径和 5. 最长回文子串 1143. 最长公共子序列 72. 编辑距离
算法·leetcode·动态规划
CoderCodingNo3 小时前
【GESP】C++五级练习题 luogu-P1182 数列分段 Section II
开发语言·c++·算法
放下华子我只抽RuiKe53 小时前
机器学习全景指南-直觉篇——基于距离的 K-近邻 (KNN) 算法
人工智能·gpt·算法·机器学习·语言模型·chatgpt·ai编程
kisshuan123963 小时前
[特殊字符]【深度学习】DA3METRIC-LARGE单目深度估计算法详解
人工智能·深度学习·算法
阿珍爱上了阿强,在一个有星星的夜晚3 小时前
node后端页面性能监测分析
java·学习方法
sali-tec3 小时前
C# 基于OpenCv的视觉工作流-章33-Blod分析
图像处理·人工智能·opencv·算法·计算机视觉