给定一组不含重复元素的整数数组 nums,返回该数组所有可能的子集(幂集)。
说明:解集不能包含重复的子集。
示例: 输入: nums = [1,2,3] 输出: [ [3], [1], [2], [1,2,3], [1,3], [2,3], [1,2], [] ]
思路:
子集问题相当于回溯过程中,记录所有的节点。
class Solution {
public:
vector<int> tmp;
vector<vector<int>> ans;
public:
void dfs(vector<int>& nums, int idx) {
ans.emplace_back(tmp);
if (idx >= nums.size()) return;
for(int i=idx;i<nums.size();++i) {
tmp.emplace_back(nums[i]);
dfs(nums, i+1);
tmp.pop_back();
}
}
vector<vector<int>> subsets(vector<int>& nums) {
dfs(nums, 0);
return ans;
}
};