39. 组合总和
✅做题思路or感想
这里依旧是找组合,故依旧是用回溯法
而因为这里的元素是可以重复选取的,所以这里的startIndex
在递归时不需要+1,或者直接干脆不用startIndex
就可以了
但是为了防止[2,2,3],[2,3,2]
这种重复,所以需要安排一下子集都是要递增的就好了
class Solution {
public:
vector<int>temp;
vector<vector<int>>result;
//这里直接取消了startIndex,不需要再强制性的缩小取值范围了,因为单个值可以无限的取
void dfs(vector<int>& candidates, int target) {
if (target < 0)return; //容易想到且有效的剪枝
if (target == 0) { //递归中止条件
result.push_back(temp);
return;
}
//处理数据
for (int i = 0; i < candidates.size(); i++) {
//这里if是维持子集是单调递增的!
if (temp.size() != 0 && temp.back() <= candidates[i] || temp.size() == 0) {
temp.push_back(candidates[i]);
dfs(candidates, target - candidates[i]);
temp.pop_back();//回溯
}
}
}
vector<vector<int>> combinationSum(vector<int>& candidates, int target) {
dfs(candidates, target);
return result;
}
};
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 因为Apifox不支持离线,我果断选择了Apipost!
· 通过 API 将Deepseek响应流式内容输出到前端