This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <bits/stdc++.h>
#include "roads.h"
using namespace std;
const int MAX_N = 1e5 + 5;
long long dp[MAX_N];
bool used[MAX_N];
vector <long long> minimum_closure_costs(int N, vector <int> U, vector <int> V, vector <int> W) {
bool subtask1 = true, subtask2 = true;
for(int i = 0; i < N - 1; i++) {
if(U[i] != 0 and V[i] != 0) {
subtask1 = false;
}
if(U[i] != i or V[i] != i + 1) {
subtask2 = false;
}
}
vector <long long> ans;
if(subtask1 == true) {
sort(W.rbegin(), W.rend());
long long sum = 0;
for(int i = 0; i < N - 1; i++) {
sum += W[i];
}
for(int i = 0; i < N - 1; i++) {
ans.push_back(sum);
sum -= W[i];
}
ans.push_back(0);
}
else if(subtask2 == true) {
long long sum = 0;
for(int i = 0; i < N - 1; i++) {
sum += W[i];
}
ans.push_back(sum);
for(int i = 0; i < N - 1; i++) {
dp[i] = W[i];
if(i - 1 >= 0) {
dp[i] = max(dp[i], dp[i - 1]);
}
if(i - 2 >= 0) {
dp[i] = max(dp[i], dp[i - 2] + W[i]);
}
}
ans.push_back(sum - dp[N - 2]);
for(int i = 0; i < N - 2; i++) {
ans.push_back(0);
}
}
else if(N <= 200) {
// do something
}
else if(N <= 2000) {
// do something
}
return ans;
}
# | 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... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |