77. 组合

思路

通过递归函数dfs,从1到n的数字中选择k个数的所有组合。函数维护当前组合b,当b大小达到k时存入结果。每次递归从当前起始点i+1继续搜索,避免重复组合。

时间复杂度为O(C(n,k)),空间复杂度为O(k)递归栈空间。

代码

cpp 复制代码
class Solution {
private:
    vector<vector<int>> da;
    vector<int> b;
    void dfs(int n,int k,int a) {
        if(b.size()==k) {
            da.push_back(b);
            return;
        }
        for(int i=a;i<=n;i++) {
            b.push_back(i); 
            dfs(n,k,i+1); 
            b.pop_back(); 
        }
    }
public:
    vector<vector<int>> combine(int n,int k) {
        dfs(n,k,1);
        return da;
    }
相关推荐
code_pgf2 分钟前
Octo 算法详解-开源通用机器人策略模型技术报告
算法·机器人·开源
cany100010 分钟前
C++ -- 模板的声明和定义
开发语言·c++
澈20711 分钟前
深耕进阶 Day1:C 与 C++ 核心差异 + C++ 入门基石
c语言·开发语言·c++
嘻嘻哈哈樱桃13 分钟前
牛客经典101题题解集--动态规划
java·数据结构·python·算法·职场和发展·动态规划
脱氧核糖核酸__29 分钟前
LeetCode热题100——234.回文链表(两种解法)
c++·算法·leetcode·链表
IronMurphy29 分钟前
【算法四十二】118. 杨辉三角 198. 打家劫舍
算法
电科一班林耿超34 分钟前
第 16 课:动态规划专题(二)—— 子序列与子数组问题:面试最高频的 DP 题型
数据结构·算法·动态规划
愚者游世36 分钟前
noexcept 说明符与 noexcept运算符各版本异同
开发语言·c++·程序人生·面试·visual studio
生信研究猿1 小时前
leetcode 416. 分割等和子集
算法·leetcode·职场和发展
狗哥哥1 小时前
面包屑自动推导的算法设计:从“最短路径匹配”到工程可落地
算法·架构