1. 程式人生 > >LeetCode 中級 - 組合總和II(105)

LeetCode 中級 - 組合總和II(105)

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)