最近在忙毕业论文开题的事情,比较忙。
时间就像海绵里面的水,挤一挤啊
已经收归于 专题:回溯算法专题(已完结)
题目:
78. 子集
给定一组不含重复元素的整数数组 nums,返回该数组所有可能的子集(幂集)。
说明:解集不能包含重复的子集。
示例:
输入: nums = [1,2,3]
输出:
[
[3],
[1],
[2],
[1,2,3],
[1,3],
[2,3],
[1,2],
[]
]
思路:
这题我想到的是两种方法一个是使用组合问题,一个是使用每次判断是否需要选择indx新元素
方法一:
略:
方法二:
class Solution {
private:
vector<vector<int>> ret_v;
void _subsets(vector<int>&nums,int index, vector<int> temp_v)
{
if(index>=nums.size())
{
ret_v.push_back(temp_v);
return;
}
//不要当前数据
_subsets(nums,index+1,temp_v);
//将当前数据进行保存
temp_v.push_back(nums[index]);
_subsets(nums,index+1,temp_v);
}
public:
vector<vector<int>> subsets(vector<int>& nums)
{
vector<int> temp_v;
int index=0;
_subsets(nums,index,temp_v);
return ret_v;
}
};