给你一个整数数组 nums ,其中可能包含重复元素,请你返回该数组所有可能的子集(幂集)。
解集 不能 包含重复的子集。返回的解集中,子集可以按 任意顺序 排列。
> 我的解法
class Solution {
private:
void traversal(vector<int> &nums,vector<bool> &used,int startdex){
if(startdex > nums.size()) return;
res.emplace_back(path);
for(int i = startdex;i < nums.size(); i++){
if(i > 0 && nums[i - 1] == nums[i] && used[i - 1] == false) continue;
path.emplace_back(nums[i]);
used[i] = true;
traversal(nums,used,i+1);
used[i] = false;
path.pop_back();
}
}
public:
vector<vector<int>> res;
vector<int> path;
vector<vector<int>> subsetsWithDup(vector<int>& nums) {
vector<bool> used(nums.size(),false);
res.clear();
path.clear();
used.clear();
std::sort(nums.begin(),nums.end());
traversal(nums,used,0);
return res;
}
};
标签:used,nums,res,II,vector,子集,path,90
From: https://www.cnblogs.com/lihaoxiang/p/17320922.html