给定两个整数 n 和 k,返回 1 ... n 中所有可能的 k 个数的组合。
使用深度优先搜索算法,这道题博主写得不好,效率较低,有待改进。
class Solution {
public:
vector<vector<int>> combine(int n, int k) {
vector<vector<int>> res;
vector<int> tmp;
dfs(res, tmp, 1, k, n);
return res;
}
void dfs(vector<vector<int>> &res, vector<int> tmp, int start, int k, int n)
{
if(k == 0)
{
res.push_back(tmp);
return;
}
for(int i = start; i <= n; ++i)
{
tmp.push_back(i);
dfs(res, tmp, i + 1, k - 1, n);
tmp.pop_back();
}
}
};