90. 子集 II

给你一个整数数组 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;
    }
};
posted @   xiazichengxi  阅读(11)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
点击右上角即可分享
微信分享提示
主题色彩