mirror of
https://github.com/20kaushik02/leetcode-gulag.git
synced 2025-12-06 05:24:07 +00:00
day 15: 78-subsets
This commit is contained in:
parent
7375af90a8
commit
3de8ed3745
15
78-subsets/driver.cpp
Normal file
15
78-subsets/driver.cpp
Normal file
@ -0,0 +1,15 @@
|
||||
#include "soln.hpp"
|
||||
|
||||
int main() {
|
||||
vector<int> nums{1,2,3};
|
||||
Solution soln;
|
||||
vector<vector<int>> answer = soln.subsets(nums);
|
||||
for(int i = 0; i < answer.size(); i++) {
|
||||
cout << "Subset " << (i+1) << ": ";
|
||||
for(int j = 0; j < answer[i].size(); j++) {
|
||||
cout << answer[i][j] << " ";
|
||||
}
|
||||
cout << endl;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
19
78-subsets/soln.cpp
Normal file
19
78-subsets/soln.cpp
Normal file
@ -0,0 +1,19 @@
|
||||
#include "soln.hpp"
|
||||
|
||||
vector<vector<int>> Solution::subsets(vector<int> &nums)
|
||||
{
|
||||
int num_combos = 1 << nums.size();
|
||||
vector<vector<int>> subs(num_combos);
|
||||
for (int i = 0; i < num_combos; i++)
|
||||
{
|
||||
for (int j = 0; j < nums.size(); j++)
|
||||
{
|
||||
// check if this index exists in this combo
|
||||
if ((i >> j) & 1)
|
||||
{
|
||||
subs[i].push_back(nums[j]);
|
||||
}
|
||||
}
|
||||
}
|
||||
return subs;
|
||||
}
|
||||
7
78-subsets/soln.hpp
Normal file
7
78-subsets/soln.hpp
Normal file
@ -0,0 +1,7 @@
|
||||
#include <bits/stdc++.h>
|
||||
using namespace std;
|
||||
class Solution
|
||||
{
|
||||
public:
|
||||
vector<vector<int>> subsets(vector<int> &nums);
|
||||
};
|
||||
Loading…
x
Reference in New Issue
Block a user