标签:
Given a set of distinct integers, nums, return all possible subsets.
Note: The solution set must not contain duplicate subsets.
For example,
If nums = [1,2,3]
, a solution is:
[ [3], [1], [2], [1,2,3], [1,3], [2,3], [1,2], [] ]
思路:
方法一:
先求出子集的个数subset_num=2^(nums.size())。对于每个元素,每个子集只有2种可能:包含或不包含,那么只要按照顺序添加对应元素就可以了。
j表示的是第j个子集,j可以被表示成subset_num二进制位,第i位表示的是第j个子集包含元素nums[i]的情况:j的第i位为1表示当前子集包含nums[i];j的第i位为0表示当前子集不包含nums[i]。
方法二:
回溯法构造子集,subsets(vector<vector<int> > &res,vector<int> nums,int cur)含义是当前res中未有包含nums[cur]的子集,下面要建立所有包含元素nums[cur]的子集。
代码:
方法一:
1 class Solution { 2 public: 3 vector<vector<int> > subsets(vector<int>& nums) { 4 int n=nums.size(),subset_num=pow(2,n); 5 vector<vector<int> > res(subset_num,vector<int>{}); 6 for(int i=0;i<n;i++){ 7 for(int j=0;j<subset_num;j++){ 8 if(j>>i&1){ 9 res[j].push_back(nums[i]); 10 } 11 } 12 } 13 return res; 14 } 15 };
方法二:
1 class Solution { 2 public: 3 vector<vector<int> > res; 4 vector<int> v; 5 void subsets(vector<vector<int> > &res,vector<int> nums,int cur){ 6 res.push_back(v); 7 for(int i=cur;i<nums.size();i++){ 8 v.push_back(nums[i]); 9 subsets(res,nums,i+1); 10 v.pop_back(); 11 } 12 } 13 vector<vector<int> > subsets(vector<int>& nums) { 14 subsets(res,nums,0); 15 return res; 16 } 17 };
标签:
原文地址:http://www.cnblogs.com/Deribs4/p/5724675.html