이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
using namespace std;
using ll = long long;
const int N = 2000 + 5;
const ll inf = 1e17;
vector<ll> last, curr;
int n, m;
vector<ll> c, f, v, type;
bool cmp(const int &a, const int &b)
{
if (f[a] != f[b]) return f[a] > f[b];
return type[a] < type[b];
}
int main()
{
int cores = 0;
cin >> n;
c.resize(4000);
f.resize(4000);
v.resize(4000);
type.resize(4000);
for(int i = 0; i < n; i++)
{
cin >> c[i] >> f[i] >> v[i];
type[i] = -1;
cores += c[i];
}
cin >> m;
for(int i = 0; i < m; i++)
{
cin >> c[n + i] >> f[n + i] >> v[n + i];
type[n + i] = 1;
}
vector<int> j(n + m);
iota(j.begin(), j.end(), 0);
sort(j.begin(), j.end(), cmp);
last.assign(cores + 5, -inf);
curr.assign(cores + 5, -inf);
last[0] = curr[0] = 0;
for(const int &i : j)
{
curr = last;
if(type[i] == -1)
{
for(int j = c[i]; j <= cores; j++)
curr[j] = max(curr[j], last[j - c[i]] - v[i]);
}
else
{
for(int j = 0; j <= cores - c[i]; j++)
curr[j] = max(curr[j], last[j + c[i]] + v[i]);
}
last.swap(curr);
}
cout << *max_element(last.begin(), last.end());
return 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... |