-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathSubsetsII.cpp
61 lines (48 loc) · 1.16 KB
/
SubsetsII.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
void printSubsets(vector<int> &arr, vector<int> &ans, int i, vector<vector<int>> &allSubsets)
{
if (i == arr.size())
{
allSubsets.push_back(ans);
return;
}
// Inclusion
ans.push_back(arr[i]);
printSubsets(arr, ans, i + 1, allSubsets);
ans.pop_back(); // backtrack
int idx = i + 1; // to skip duplicates
while (idx < arr.size() && arr[idx] == arr[idx - 1])
{
idx++;
}
// Exclusion
printSubsets(arr, ans, idx, allSubsets);
}
vector<vector<int>> subsetsWithDup(vector<int> &arr)
{
sort(arr.begin(), arr.end()); // sort the array first
vector<vector<int>> allSubsets;
vector<int> ans;
printSubsets(arr, ans, 0, allSubsets);
return allSubsets;
}
int main()
{
vector<int> arr = {1, 2, 2};
vector<vector<int>> result = subsetsWithDup(arr);
// Printing the subsets
cout << "Unique subsets are:\n";
for (const auto &subset : result)
{
cout << "{ ";
for (int num : subset)
{
cout << num << " ";
}
cout << "}\n";
}
return 0;
}