이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include "molecules.h"
#define fi first
#define se second
#include <bits/stdc++.h>
using namespace std;
std::vector<int> find_subset(int l, int u, std::vector<int> w) {
int n = w.size();
vector<pair<int, int>> s;
for (int i = 0; i < n; i++) {
s.push_back(make_pair(w[i], i));
}
sort(s.begin(), s.end());
vector<int> sp (n, 0);
vector<int> ss (n, 0);
sp[0] = s[0].fi;
ss[n-1] = s[n-1].fi;
for (int i = 1; i < n; i++) {
sp[i] = sp[i-1]+s[i].fi;
ss[n-1-i] = ss[n-i]+s[n-1-i].fi;
}
for (int i = 0; i < n; i++) {
if (sp[i] <= u && ss[n-1-i] >= l) {
vector<int> v;
int sum = 0;
for (int j = 0; j <= i; j++) {
v.push_back(s[j].se);
sum += s[j].fi;
}
for (int j = 0; j <= i; j++) {
if (sum < l) {
sum -= s[j].fi;
sum += s[n-1-j].fi;
v[j] = s[n-1-j].se;
}
}
return v;
}
}
return vector<int>(0);
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |