给定一组不含重复元素的整数数组 nums,返回该数组所有可能的子集(幂集)。
说明:解集不能包含重复的子集。
示例:
输入: nums = [1,2,3]
输出:
[
[3],
[1],
[2],
[1,2,3],
[1,3],
[2,3],
[1,2],
[]
]
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/subsets
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
参考:
https://mp.weixin.qq.com/s/sekv_I7o6-3Jz6y-ZF2u-w
思路:
是回溯法的应用,以1,2,3为例
是依次固定一个元素,后面的元素依次入队,并且每一次都要加入到答案中
class Solution {
public:
vector<vector<int>> subsets(vector<int>& nums)
{
vector<vector<int>> ret;
vector<int> tmp;
sort(nums.begin(), nums.end());
backtrack(ret, tmp, nums, 0);
return ret;
}
void backtrack(vector<vector<int>>& ret, vector<int> &tempList, vector<int>& nums, int start)
{
ret.push_back(tempList);
for(int i = start; i < nums.size(); i++)
{
tempList.push_back(nums[i]);
backtrack(ret, tempList, nums, i+1);
tempList.erase(tempList.begin() + tempList.size() - 1);
}
}
};