###### tags: `LeetCode` `Medium` `DFS` `Recursion`
# LeetCode #90 [Subsets II](https://leetcode.com/problems/subsets-ii/)
### (Medium)
給定一個可能包含重複項的整數數組 nums,返回所有可能的子集(冪集)。
解決方案集不得包含重複的子集。 可以任何順序返回解答。
---
這題與#78類似, 唯一差別是有重複元素, 因此只要加上防止重複判定即可。
---
```
class Solution {
public:
vector<vector<int>> subsetsWithDup(vector<int>& nums) {
vector<int> tmp;
vector<vector<int>> ans;
sort(nums.begin(), nums.end());
for(int i=0;i<=nums.size();i++){
dfs(nums, i, 0, tmp, ans);
}
return ans;
}
void dfs(vector<int>& nums, int n, int pos, vector<int>& tmp, vector<vector<int>>& ans){
if(tmp.size()==n){
ans.push_back(tmp);
return;
}
for(int i=pos;i<nums.size();i++){
if(i==pos||nums[i]!=nums[i-1]){
tmp.push_back(nums[i]);
dfs(nums, n, i+1, tmp, ans);
tmp.pop_back();
}
}
}
};
```