地址 https://leetcode-cn.com/problems/subsets-ii/
给定一个可能包含重复元素的整数数组 nums,返回该数组所有可能的子集(幂集)。 说明:解集不能包含重复的子集。
示例: 输入: [1,2,2] 输出: [ [2], [1], [1,2,2], [2,2], [1,2], [] ]
使用DFS 这里取了个巧 使用set做了去重
class Solution { public: set<vector<int>> sv; void dfs(int idx,vector<int>& nums,vector<int> v) { if(idx >= nums.size()) return; sv.insert(v); dfs(idx+1,nums,v); v.push_back(nums[idx]); sv.insert(v); dfs(idx+1,nums,v); } vector<vector<int>> subsetsWithDup(vector<int>& nums) { sort(nums.begin(),nums.end()); vector<int> v; dfs(0,nums,v); vector<vector<int>> ret(sv.begin(),sv.end()); return ret; } };