【代码随想录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;
    }
};
相关推荐
lxh011320 分钟前
螺旋数组题解
前端·算法·js
铭哥的编程日记39 分钟前
《斩获字节跳动offer 最详细的面试真题与破解思路》第一期
面试·职场和发展
czlczl200209251 小时前
算法:二叉树的公共祖先
算法
稚辉君.MCA_P8_Java2 小时前
Gemini永久会员 Java动态规划
java·数据结构·leetcode·排序算法·动态规划
小白程序员成长日记2 小时前
2025.11.23 力扣每日一题
算法·leetcode·职场和发展
16_one3 小时前
autoDL安装Open-WebUi+Rag本地知识库问答+Function Calling
人工智能·后端·算法
散峰而望4 小时前
C++数组(三)(算法竞赛)
开发语言·c++·算法·github
q***95224 小时前
SpringMVC 请求参数接收
前端·javascript·算法
初级炼丹师(爱说实话版)4 小时前
多进程与多线程的优缺点及适用场景总结
算法
hetao17338375 小时前
2025-11-25~26 hetao1733837的刷题记录
c++·算法