leetcode第一刷_Subsets II


要求子集,有很现成的方法。N个数。子集的个数是2^N。每一个元素都有在集合中和不在集合中两种状态,这些状态用[0,pow(2,N)]中每一个数来穷举,假设这个数中的第i位为1,说明当前集合中包括源数组中的第i个数。

至于有没有反复的元素,大部分有反复元素的问题,都能够借助一个vis集合,里面存放全部已经求得的集合或者其它形式的解。仅仅有少数题目会超时,哪些问题详细的说。

class Solution {
public:
    vector<vector<int> > subsetsWithDup(vector<int> &S) {
        int msize = S.size();
        int mindex = pow(2, msize);
        vector<vector<int> > res;
        set<vector<int> > mset;
        vector<int> tpres;
        sort(S.begin(), S.end());
        for(int i=0;i<mindex;i++){
            int mask = 1;
            for(int pos=0;pos<msize;pos++){
                if(mask&i)  tpres.push_back(S[pos]);
                mask<<=1;
            }
            if(find(mset.begin(), mset.end(), tpres) == mset.end()){
                mset.insert(tpres);
                res.push_back(tpres);
            }
            tpres.clear();
        }
        return res;
    }
};


优质内容筛选与推荐>>
1、shell crlf to lf
2、JZ2440
3、依赖注册
4、SQL触发器 常用语句
5、LongAccumulator 源码分析


长按二维码向我转账

受苹果公司新规定影响,微信 iOS 版的赞赏功能被关闭,可通过二维码转账支持公众号。

    阅读
    好看
    已推荐到看一看
    你的朋友可以在“发现”-“看一看”看到你认为好看的文章。
    已取消,“好看”想法已同步删除
    已推荐到看一看 和朋友分享想法
    最多200字,当前共 发送

    已发送

    朋友将在看一看看到

    确定
    分享你的想法...
    取消

    分享想法到看一看

    确定
    最多200字,当前共

    发送中

    网络异常,请稍后重试

    微信扫一扫
    关注该公众号