40. 组合总和 II
✅做题思路or感想
这题主思路是回溯
要注意的是会有元素的重复,所以这里要做树层去重
以下去重是需要在排序后才能进行!!!!
在candidates[i]
与candidates[i - 1]
相同的情况下:
- 如果
used[i - 1] == true
,则说明同一树枝使用过candidates[i - 1]
- 如果
used[i - 1] == false
,则说明同一树层使用过candidates[i - 1]
如果在同一树层使用过了,则直接continue
就好了
class Solution {
public:
vector<vector<int>>result;
vector<int>temp;
void dfs(vector<int>& candidates, int target, int startIndex, vector<bool>& used) {
if (target < 0)return; //容易想到的剪枝
//若满足,则加入result中
if (target == 0) {
result.push_back(temp);
return ;
}
//这里有一个不容易想到的剪枝:target - candidates[i] >= 0,若不满足这个条件,则直接结束递归。这个递归的使用前提是要用sort排序过遍历的数组
for (int i = startIndex; i < candidates.size() && target - candidates[i] >= 0; i++) {
//树层去重
if (i > 0 && candidates[i - 1] == candidates[i] && used[i - 1] == false)continue;
temp.push_back(candidates[i]);
used[i] = true;
dfs(candidates, target - candidates[i], i + 1, used);
//回溯
used[i] = false;
temp.pop_back();
}
}
vector<vector<int>> combinationSum2(vector<int>& candidates, int target) {
//注意排序!只有sort排序后,used数组的树层去重和for中的剪枝才能实现!!!!
sort(candidates.begin(), candidates.end());
vector<bool>used(candidates.size() + 1, false);
dfs(candidates, target, 0, used);
return result;
}
};
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 因为Apifox不支持离线,我果断选择了Apipost!
· 通过 API 将Deepseek响应流式内容输出到前端