78. 子集
✅做题思路or感想
集合的经典问题,直接回溯法,递归三部曲。
递归参数
- 这里用一个
startIndex
来控制可选元素的范围,从而进行有效去重。这个做法老生常谈了
递归终止条件
- 这一题甚至不需要递归中止条件........
单层递归逻辑
- 用
result
来实时记录变化的temp
就好了
class Solution {
public:
vector<vector<int>>result;
vector<int>temp;
void dfs(vector<int>& nums, int startIndex) {
for (int i = startIndex; i < nums.size(); i++) {
temp.push_back(nums[i]); //实时记录temp
result.push_back(temp);
dfs(nums, i + 1);
temp.pop_back(); //回溯
}
}
vector<vector<int>> subsets(vector<int>& nums) {
result.push_back(temp); //值得一提的是需要先给result里面加一个空集
dfs(nums, 0);
return result;
}
};
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 因为Apifox不支持离线,我果断选择了Apipost!
· 通过 API 将Deepseek响应流式内容输出到前端