【代码随想录day 21】 力扣 77. 组合

视频讲解:https://www.bilibili.com/video/BV1ti4y1L7cv/?vd_source=a935eaede74a204ec74fd041b917810c

文档讲解:https://programmercarl.com/0077.组合.html#思路

力扣题目:https://leetcode.cn/problems/combinations/submissions/656261390/

主要思路如图所示:

对于回溯算法我们可以将其抽象为树的结构,主要思路如下:

  1. 返回值以及参数
  2. 回溯终止条件
  3. 单层回溯
cpp 复制代码
class Solution {
private:
    //存放结果数组
    vector<vector<int>> result;
    //存放符合条件的结果
    vector<int> path;
    void backtracking(int n,int k, int startIndex)
    {
        //判断终止条件
        //如果路径满足个数,就回溯
        if(path.size() == k)
        {
            result.push_back(path);
            return;
        }
        //开始回溯
        for(int i = startIndex; i<=n; i++)
        {
            //存入节点
            path.push_back(i);
            //递归处理
            backtracking(n, k, i+1);
            //回溯  弹出
            path.pop_back();
        }
    }

public:
    vector<vector<int>> combine(int n, int k) {
        result.clear();
        path.clear();
        backtracking(n, k, 1);
        return result;
    }
};
相关推荐
Tisfy3 分钟前
LeetCode 3010.将数组分成最小总代价的子数组 I:排序 OR 维护最小次小
算法·leetcode·题解·排序·最小次小值
Learn Beyond Limits7 分钟前
文献阅读:A Probabilistic U-Net for Segmentation of Ambiguous Images
论文阅读·人工智能·深度学习·算法·机器学习·计算机视觉·ai
m0_7369191019 分钟前
编译器命令选项优化
开发语言·c++·算法
naruto_lnq26 分钟前
C++中的工厂方法模式
开发语言·c++·算法
千逐-沐风36 分钟前
SMU-ACM2026冬训周报2nd
算法
m0_748233171 小时前
C#与C语言:5大核心语法共性
java·jvm·算法
痴儿哈哈1 小时前
C++与硬件交互编程
开发语言·c++·算法
小O的算法实验室1 小时前
2024年ESWA SCI1区TOP,异构无人机配送问题的集成多目标优化方法,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
草履虫建模2 小时前
力扣算法 121. 买卖股票的最佳时机
算法·leetcode·职场和发展·贪心算法·动态规划·一次遍历
养军博客2 小时前
C语言五天速成(可用于蓝桥杯备考 难度中等偏下)
c语言·算法·蓝桥杯