前言
题目: 77. 组合
文档: 代码随想录——组合
编程语言: C++
解题状态: 没尝试出来
思路
经典的组合问题,可以考虑使用回溯法。使用回溯法时可以根据回溯法的模板来考虑如何解决。
代码
回溯法
class Solution {
private:vector<vector<int>> res;vector<int> path;void backtracking(int n, int k, int startIndex) {if (path.size() == k) {res.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) {res.clear();path.clear();backtracking(n, k, 1);return res;}
};
- 时间复杂度: O ( n ∗ k n ) O(n * k^n) O(n∗kn)
- 空间复杂度: O ( n ) O(n) O(n)