77. 组合
✅做题思路or感想:
这道题用回溯的操作即可
值得注意的是这里为了让子集都是递增的(如[2,4],[3,5])所以这里要有一个startIndex
来控制元素的范围,使得下一个加入的元素一定比当前处理的元素大
class Solution {
public:
vector<int>temp;
vector<vector<int>>result;
void dfs(int n, int k, int startIndex) {
//递归中止条件
if (k == 0) {
result.push_back(temp);
return;
}
//这里用了startIndex来控制元素的范围
for (int i = startIndex; i <= n; i++) {
temp.push_back(i);
dfs(n, k - 1, i + 1);//这里是i + 1!!!!
temp.pop_back();//回溯,要把vector的元素拿回去
}
}
vector<vector<int>> combine(int n, int k) {
dfs(n, k, 1);
return result;
}
};
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 因为Apifox不支持离线,我果断选择了Apipost!
· 通过 API 将Deepseek响应流式内容输出到前端