题解 | 集合的子集

集合的子集

https://www.nowcoder.com/practice/1f2700e2b1904254b55765479e9b8766

#include <algorithm>
#include <vector>
class Subset {
    void dfs(const vector<int> &A, int index, vector<int> &cur, vector<vector<int>> &res){
        if (!cur.empty()) {
            res.emplace_back(cur);
        
        }
        for(int i=index;i<A.size();++i){
            cur.emplace_back(A[i]);
            dfs(A, i+1, cur, res);
            cur.pop_back();
        }

    }
public:
    vector<vector<int> > getSubsets(vector<int> A, int n) {
        // write code here
        if(n==1) return vector<vector<int>>{A};
        sort(A.rbegin(), A.rend());
        int count =1;
        vector<vector<int>> res;
        vector<int> cur;
        dfs(A, 0, cur, res);
        sort(res.rbegin(), res.rend());
        return res;


        
    }
};

全部评论

相关推荐

02-16 01:39
南昌大学 Java
坚持无悔意无休:xhs上集美最爱说谎博人眼球
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务