###### 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(); } } } }; ```