#include "molecules.h"
#include<bits/stdc++.h>
using namespace std;
const int N = 1e4 + 10;
bool dp[N][N];
int n;
vector<int> ans;
bool ok = 0;
void get(vector<int> arr, int i, int sum, vector<int> an){
if(ok)return;
if(i == 0 && sum != 0 && dp[n - 1][sum]){
an.push_back(i);
for(int a = 0; a < an.size(); a++){
ans.push_back(an[a]);
}
ok = 1;
return;
}
if(i == 0 && sum == 0){
for(int a = 0; a < an.size(); a++){
ans.push_back(an[a]);
}
ok = 1;
return;
}
if(dp[i - 1][sum]){
get(arr, i - 1, sum, an);
}
if(sum >= arr[i]){
if(!dp[i - 1][sum - arr[i]])return;
an.push_back(i);
get(arr, i - 1, sum - arr[i], an);
}
}
std::vector<int> find_subset(int l, int u, std::vector<int> w) {
n = w.size();
for(int j = 0; j < n; j++){
for(int i = 0; i <= j; i++){
dp[i][w[j]] = 1;
}
dp[j][0] = 1;
}
for(int i = 1; i < n; i++){
for(int j = 0; j <= 1e4; j++){
if(j >= w[i]){
dp[i][j] = dp[i - 1][j - w[i]] || dp[i - 1][j];
}
else{
dp[i][j] = dp[i - 1][j];
}
}
}
for(int i = l; i <= u; i++){
if(dp[n - 1][i]){
get(w, n - 1, i, ans);
break;
}
}
sort(ans.begin(), ans.end());
return ans;
}
Compilation message
molecules.cpp: In function 'void get(std::vector<int>, int, int, std::vector<int>)':
molecules.cpp:15:26: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
15 | for(int a = 0; a < an.size(); a++){
| ~~^~~~~~~~~~~
molecules.cpp:22:26: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
22 | for(int a = 0; a < an.size(); a++){
| ~~^~~~~~~~~~~
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
1 ms |
384 KB |
OK (n = 1, answer = NO) |
2 |
Correct |
0 ms |
256 KB |
OK (n = 1, answer = NO) |
3 |
Correct |
0 ms |
256 KB |
OK (n = 1, answer = YES) |
4 |
Correct |
1 ms |
384 KB |
OK (n = 2, answer = YES) |
5 |
Correct |
0 ms |
384 KB |
OK (n = 2, answer = YES) |
6 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = YES) |
7 |
Correct |
1 ms |
384 KB |
OK (n = 3, answer = YES) |
8 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = YES) |
9 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = YES) |
10 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = YES) |
11 |
Correct |
1 ms |
384 KB |
OK (n = 3, answer = YES) |
12 |
Correct |
1 ms |
276 KB |
OK (n = 3, answer = YES) |
13 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = NO) |
14 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = YES) |
15 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = YES) |
16 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = NO) |
17 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = NO) |
18 |
Correct |
2 ms |
1280 KB |
OK (n = 100, answer = NO) |
19 |
Correct |
2 ms |
1408 KB |
OK (n = 100, answer = YES) |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Incorrect |
1 ms |
384 KB |
sum of weights should be in [302..304] but it is 301 |
2 |
Halted |
0 ms |
0 KB |
- |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
1 ms |
384 KB |
OK (n = 1, answer = NO) |
2 |
Correct |
0 ms |
256 KB |
OK (n = 1, answer = NO) |
3 |
Correct |
0 ms |
256 KB |
OK (n = 1, answer = YES) |
4 |
Correct |
1 ms |
384 KB |
OK (n = 2, answer = YES) |
5 |
Correct |
0 ms |
384 KB |
OK (n = 2, answer = YES) |
6 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = YES) |
7 |
Correct |
1 ms |
384 KB |
OK (n = 3, answer = YES) |
8 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = YES) |
9 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = YES) |
10 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = YES) |
11 |
Correct |
1 ms |
384 KB |
OK (n = 3, answer = YES) |
12 |
Correct |
1 ms |
276 KB |
OK (n = 3, answer = YES) |
13 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = NO) |
14 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = YES) |
15 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = YES) |
16 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = NO) |
17 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = NO) |
18 |
Correct |
2 ms |
1280 KB |
OK (n = 100, answer = NO) |
19 |
Correct |
2 ms |
1408 KB |
OK (n = 100, answer = YES) |
20 |
Incorrect |
1 ms |
384 KB |
sum of weights should be in [302..304] but it is 301 |
21 |
Halted |
0 ms |
0 KB |
- |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
1 ms |
384 KB |
OK (n = 1, answer = NO) |
2 |
Correct |
0 ms |
256 KB |
OK (n = 1, answer = NO) |
3 |
Correct |
0 ms |
256 KB |
OK (n = 1, answer = YES) |
4 |
Correct |
1 ms |
384 KB |
OK (n = 2, answer = YES) |
5 |
Correct |
0 ms |
384 KB |
OK (n = 2, answer = YES) |
6 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = YES) |
7 |
Correct |
1 ms |
384 KB |
OK (n = 3, answer = YES) |
8 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = YES) |
9 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = YES) |
10 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = YES) |
11 |
Correct |
1 ms |
384 KB |
OK (n = 3, answer = YES) |
12 |
Correct |
1 ms |
276 KB |
OK (n = 3, answer = YES) |
13 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = NO) |
14 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = YES) |
15 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = YES) |
16 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = NO) |
17 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = NO) |
18 |
Correct |
2 ms |
1280 KB |
OK (n = 100, answer = NO) |
19 |
Correct |
2 ms |
1408 KB |
OK (n = 100, answer = YES) |
20 |
Incorrect |
1 ms |
384 KB |
sum of weights should be in [302..304] but it is 301 |
21 |
Halted |
0 ms |
0 KB |
- |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
1 ms |
384 KB |
OK (n = 1, answer = NO) |
2 |
Correct |
0 ms |
256 KB |
OK (n = 1, answer = NO) |
3 |
Correct |
0 ms |
256 KB |
OK (n = 1, answer = YES) |
4 |
Correct |
1 ms |
384 KB |
OK (n = 2, answer = YES) |
5 |
Correct |
0 ms |
384 KB |
OK (n = 2, answer = YES) |
6 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = YES) |
7 |
Correct |
1 ms |
384 KB |
OK (n = 3, answer = YES) |
8 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = YES) |
9 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = YES) |
10 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = YES) |
11 |
Correct |
1 ms |
384 KB |
OK (n = 3, answer = YES) |
12 |
Correct |
1 ms |
276 KB |
OK (n = 3, answer = YES) |
13 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = NO) |
14 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = YES) |
15 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = YES) |
16 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = NO) |
17 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = NO) |
18 |
Correct |
2 ms |
1280 KB |
OK (n = 100, answer = NO) |
19 |
Correct |
2 ms |
1408 KB |
OK (n = 100, answer = YES) |
20 |
Incorrect |
1 ms |
384 KB |
sum of weights should be in [302..304] but it is 301 |
21 |
Halted |
0 ms |
0 KB |
- |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
1 ms |
384 KB |
OK (n = 1, answer = NO) |
2 |
Correct |
0 ms |
256 KB |
OK (n = 1, answer = NO) |
3 |
Correct |
0 ms |
256 KB |
OK (n = 1, answer = YES) |
4 |
Correct |
1 ms |
384 KB |
OK (n = 2, answer = YES) |
5 |
Correct |
0 ms |
384 KB |
OK (n = 2, answer = YES) |
6 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = YES) |
7 |
Correct |
1 ms |
384 KB |
OK (n = 3, answer = YES) |
8 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = YES) |
9 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = YES) |
10 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = YES) |
11 |
Correct |
1 ms |
384 KB |
OK (n = 3, answer = YES) |
12 |
Correct |
1 ms |
276 KB |
OK (n = 3, answer = YES) |
13 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = NO) |
14 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = YES) |
15 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = YES) |
16 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = NO) |
17 |
Correct |
0 ms |
384 KB |
OK (n = 3, answer = NO) |
18 |
Correct |
2 ms |
1280 KB |
OK (n = 100, answer = NO) |
19 |
Correct |
2 ms |
1408 KB |
OK (n = 100, answer = YES) |
20 |
Incorrect |
1 ms |
384 KB |
sum of weights should be in [302..304] but it is 301 |
21 |
Halted |
0 ms |
0 KB |
- |