您的位置:首页 > 其它

子集

2018-01-29 21:56 92 查看
给定一个含不同整数的集合,返回其所有的子集


注意事项


子集中的元素排列必须是非降序的,解集必须不包含重复的子集

您在真实的面试中是否遇到过这个题?

Yes

样例

如果 S =
[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>> numsets;
vector<int> numset;
subsets(nums, numsets, numset, 0);
return numsets;
}
void subsets(const vector<int> &nums,
vector<vector<int>> &numsets,
vector<int> numset,
int pos) {
numsets.push_back(numset);
for (int i = pos; i < nums.size(); i++) {
numset.push_back(nums[i]);
subsets(nums, numsets, numset, i + 1);
numset.pop_back();
}
}
};
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: