leetcode第77题
class Solution {
public:
vector<vector<int>> ans;
vector<int> temp;
//对于每一位有两种情况选择或者不选择,cur表示当前那一位
void dfs(int n,int k,int cur)
{
//剪枝:如果已经选择了cur位,但是1-n可以选择的位数和cur的和加起来小于k,不可能达到题目条件,返回
if(temp.size()+n-cur+1<k)
return;
if(temp.size()==k)
{
ans.push_back(temp);
return;
}
//退出循环的条件,选择数字的范围超过了n
if(cur==n+1)
return;
temp.push_back(cur);
//选择当前这个数字进入下一轮
dfs(n,k,cur+1);
temp.pop_back();
//不选择当前这个数字进入下一个数字
dfs(n,k,cur+1);
}
vector<vector<int>> combine(int n, int k) {
dfs(n,k,1);
return ans;
}
};