이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
#include "roads.h"
using namespace std;
const int MAX_N = 1e5 + 5;
int id[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) {
iota(id, id + N - 1, 0);
sort(id, id + N - 1, [&](const int &a, const int &b) {
return W[a] > W[b];
});
long long sum = 0;
for(int i = 0; i < N - 1; i++) {
sum += W[id[i]];
}
ans.push_back(sum);
for(int i = 0; i < N - 1; i++) {
if(used[U[id[i]]] == false and used[V[id[i]]] == false) {
sum -= W[id[i]];
used[U[id[i]]] = true;
used[V[id[i]]] = true;
}
}
ans.push_back(sum);
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... |