给定一个含不同整数的集合,返回其所有的子集。
样例
样例 1:
输入:[0]
输出:
[
[],
[0]
]
样例 2:
输入:[1,2,3]
输出:
[
[3],
[1],
[2],
[1,2,3],
[1,3],
[2,3],
[1,2],
[]
]
挑战
你可以同时用递归与非递归的方式解决么?
注意事项
子集中的元素排列必须是非降序的,解集必须不包含重复的子集。
class Solution {
public:
/**
* @param nums: A set of numbers
* @return: A list of lists
*/
vector<vector<int>> subsets(vector<int> &nums)
{
// write your code here
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);
}
}
};