标签:
Given a collection of integers that might contain duplicates, S, return all possible subsets.
Note:
For example,
If S = [1,2,2]
, a solution is:
[ [2], [1], [1,2,2], [2,2], [1,2], [] ]
1 class Solution { 2 3 public: 4 5 vector<vector<int> > subsetsWithDup(vector<int> &S) { 6 7 8 9 vector<vector<int> > result; 10 11 vector<int> tmp; 12 13 sort(S.begin(),S.end()); 14 15 getSubset(result,S,0,tmp); 16 17 return result; 18 19 } 20 21 22 23 void getSubset(vector<vector<int> > &result,vector<int> &S,int index,vector<int> tmp) 24 25 { 26 27 if(index==S.size()) 28 29 { 30 31 32 33 for(int i=0;i<result.size();i++) 34 35 { 36 37 if(result[i]==tmp) 38 39 return; 40 41 } 42 43 result.push_back(tmp); 44 45 46 47 return; 48 49 } 50 51 52 53 getSubset(result,S,index+1,tmp); 54 55 tmp.push_back(S[index]); 56 57 getSubset(result,S,index+1,tmp); 58 59 } 60 61 };
1 class Solution { 2 3 public: 4 5 vector<vector<int> > subsetsWithDup(vector<int> &S) { 6 7 8 9 vector<vector<int> > result; 10 11 vector<int> tmp; 12 13 sort(S.begin(),S.end()); 14 15 getSubset(result,S,0,tmp); 16 17 return result; 18 19 } 20 21 22 23 void getSubset(vector<vector<int> > &result,vector<int> &S,int index,vector<int> tmp) 24 25 { 26 27 result.push_back(tmp); 28 29 30 31 for(int i=index;i<S.size();i++) 32 33 { 34 35 if(i>index&&S[i]==S[i-1])continue; 36 37 38 39 tmp.push_back(S[i]); 40 41 getSubset(result,S,i+1,tmp); 42 43 tmp.pop_back(); 44 45 } 46 } 47 48 };
标签:
原文地址:http://www.cnblogs.com/reachteam/p/4192425.html