题目描述
给定一组不含重复元素的整数数组 nums,返回该数组所有可能的子集(幂集)。
说明:解集不能包含重复的子集。
示例:
输入: nums = [1,2,3]
输出:
[
[3],
[1],
[2],
[1,2,3],
[1,3],
[2,3],
[1,2],
[]
]
代码实现
第一种方法:动态规划的思想
{ nums[0]…nums[i-1] } 若已知它的子集S,那么在考虑{ nums[0]…nums[i-1],nums[i] }的子集时,考虑nums[i]在不在子集内 ,即子集等于{ S, {S, nums[i]} }
class Solution {
public:
vector<vector<int>> subsets(vector<int>& nums) {
vector<vector<int>> ans;
ans.push_back({});
vector<int> s;
if(nums.size() == 0) return ans;
s.push_back(nums[0]);
ans.push_back(s);
for(int i = 1; i < nums.size(); i++){
int len = ans.size();
int len1 = len;
while(len){
ans.push_back(ans[--len]);
}
while(len1){
ans[--len1].push_back(nums[i]);
}
}
return ans;
}
};
第二种方法:位运算实现
class Solution {
public:
vector<vector<int>> subsets(vector<int>& nums) {
int S = nums.size();
int N = 1 << S;
vector<vector<int> > res;
for (int i = 0; i < N; ++i) {
vector<int> v;
for (int j = 0; j < S; ++j)
if (i & (1 << j))
v.push_back(nums[j]);
res.push_back(v);
}
return res;
}
};