【代码随想录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;
    }
};
相关推荐
flashlight_hi14 分钟前
LeetCode 分类刷题:199. 二叉树的右视图
javascript·算法·leetcode
LYFlied16 分钟前
【每日算法】LeetCode 46. 全排列
前端·算法·leetcode·面试·职场和发展
2301_8234380217 分钟前
【无标题】解析《采用非对称自玩实现强健多机器人群集的深度强化学习方法》
数据库·人工智能·算法
oscar99919 分钟前
CSP-J教程——第二阶段第十二、十三课:排序与查找算法
数据结构·算法·排序算法
chao18984426 分钟前
MATLAB与HFSS联合仿真
算法
月明长歌32 分钟前
【码道初阶】牛客TSINGK110:二叉树遍历(较难)如何根据“扩展先序遍历”构建二叉树?
java·数据结构·算法
jqrbcts34 分钟前
关于发那科机器人视觉补偿报警设置
人工智能·算法
_Li.37 分钟前
机器学习-线性判别函数
人工智能·算法·机器学习
蒲小英38 分钟前
算法-栈与队列
算法
代码游侠1 小时前
学习笔记——IPC(进程间通信)
linux·运维·网络·笔记·学习·算法