给定一个数组 candidates
和一个目标数 target
,找出 candidates
中所有可以使数字和为 target
的组合。
candidates
中的每个数字在每个组合中只能使用一次。
说明:
- 所有数字(包括目标数)都是正整数。
- 解集不能包含重复的组合。
示例 1:
输入: candidates = [10,1,2,7,6,1,5], target = 8,所求解集为:[ [1, 7], [1, 2, 5], [2, 6], [1, 1, 6]] 思路:深搜,并且出现重复数字,则删去,类似三数之和。
class Solution {
public: vector<vector<int>> combinationSum2(vector<int>& candidates, int target) { sort(candidates.begin(),candidates.end()); vector<vector<int>>res; vector<int> path; DFS(res,candidates,0,0,target,path); return res; }private: void DFS (vector<vector<int>>&res,vector<int>candidates,int pos,int sum,int target, vector<int>&path){ if(sum>=target){ if(sum==target) res.push_back(path); return ; } for(int i=pos;i<candidates.size();++i){ if(i!=pos&&candidates[i]==candidates[i-1]) continue; path.push_back(candidates[i]); DFS(res,candidates,i+1,sum+candidates[i],target,path); path.pop_back(); } }};