LeetCode 中級 - 組合總和II(105)
阿新 • • 發佈:2019-04-05
pop 行處理 lee i++ 一個 targe ++ col turn
給定一個數組 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] ]
思路:數組未說明是否含義重復元素,這題同組合總和類型,但是需要註意判重,
每個數字在每個組合中只能使用一次則下一次遞歸時,start++,為了避免數組中含有重復元素的情況,先將candidates排好序,進行處理。
class Solution { public: void dfs(vector<int> candidates,int start,int target,vector<int> item,vector<vector<int> >&res) { if(target<0) return ; if(target==0) { res.push_back(item);return ; } for(int i=start;i<candidates.size();i++) { if(i>start&&candidates[i]==candidates[i-1]) continue; //判重處理 item.push_back(candidates[i]); dfs(candidates,i+1,target-candidates[i],item,res);//i+1 item.pop_back(); } } vector<vector<int>> combinationSum2(vector<int>& candidates, int target) { vector<vector<int> >res; vector<int> item; sort(candidates.begin(),candidates.end());//排序 dfs(candidates,0,target,item,res); return res; } };
LeetCode 中級 - 組合總和II(105)