[LeetCode] 77. 组合

题目描述:

给定两个整数 nk,返回范围 [1, n] 中所有可能的 k 个数的组合。

你可以按 任何顺序 返回答案。

示例 1:

复制代码
输入:n = 4, k = 2
输出:
[
  [2,4],
  [3,4],
  [2,3],
  [1,2],
  [1,3],
  [1,4],
]

示例 2:

复制代码
输入:n = 1, k = 1
输出:[[1]]

提示:

  • 1 <= n <= 20
  • 1 <= k <= n

题目链接:

. - 力扣(LeetCode)

解题主要思路:

很简单的一道dfs,确定要递归结速条件,是否需要剪枝,什么时候进行递归,如何回溯即可。

解题代码:

cpp 复制代码
class Solution {
public:
    vector<vector<int>> ret;
    vector<int> path;
    int n, k;
    vector<vector<int>> combine(int _n, int _k) {
        n = _n, k = _k;
        dfs(1);
        return ret;
    }
    void dfs(int pos)
    {   
        // 结速条件
        if (path.size() == k) {
            ret.push_back(path);
            return;
        }

        for (int i = pos; i <= n; ++i) {
            path.push_back(i);  
            dfs(i+1);  // 递归
            path.pop_back();  // 回溯
        }
    }
};
相关推荐
一拳一个呆瓜43 分钟前
【STL】_SCL_SECURE_NO_WARNINGS
c++·stl
小小编程路1 小时前
C++ 异常 完整讲解
开发语言·c++
一只齐刘海的猫3 小时前
【Leetcode】找到字符串中所有字母异位词
算法·leetcode·职场和发展
海清河晏1114 小时前
数据结构 | 八大排序
数据结构·算法·排序算法
Frank学习路上4 小时前
【C++】面试:关键字与语法特性
c++·面试
liulilittle4 小时前
固定数组时间轮的槽过载优化:桶链表与批次执行
网络·数据结构·链表
IronMurphy5 小时前
【算法五十七】146. LRU 缓存
算法·缓存
Irissgwe5 小时前
数据结构-栈和队列
数据结构·c++·c·栈和队列
两片空白5 小时前
数据容器集合set/frozenset
数据结构