首页 > 其他 > 详细

(LeetCode 78)SubSets

时间:2015-04-25 22:34:25      阅读:327      评论:0      收藏:0      [点我收藏+]

Given a set of distinct integers, S, return all possible subsets.

Note:

  • Elements in a subset must be in non-descending order.
  • The solution set must not contain duplicate subsets.

 

技术分享

题目要求 :求整数数组的所有子集

注意:

1、子集元素按非降序排列

2、不包含重复的子集

解题思路:

求解这类诸如子集的题目,都可以采用回溯法。(剪枝+递归)

 

代码如下:

class Solution {
private:
    vector<vector<int> > ans;
public:
    void collectSubSet(vector<int> &S,vector<int> x,int len,int idx){
        if(idx==len){
            vector<int> subset;
            for(int i=0;i<len;i++){
                if(x[i]!=0)
                    subset.push_back(S[i]);
            }
            sort(subset.begin(),subset.end(),less<int>());
            ans.push_back(subset);
            return;
        }
        x[idx]=0;
        collectSubSet(S,x,len,idx+1);
        x[idx]=1;
        collectSubSet(S,x,len,idx+1);
    }

    vector<vector<int> > subsets(vector<int> &S) {
        int len=S.size();
        vector<int> x(len);
 //       sort(S.begin(),S.end(),greater<int>());
        collectSubSet(S,x,len,0);
//        sort(ans.begin(),ans.end(),cmp());
        return ans;
    }
};

(LeetCode 78)SubSets

原文:http://www.cnblogs.com/AndyJee/p/4456720.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!