이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include "wiring.h"
#include <bits/stdc++.h>
using namespace std;
#define rep(i , j , k) for(int i = j; i < (int)k; i++)
#define all(x) x.begin(),x.end()
typedef long long ll;
ll min_total_length(std::vector<int> R, std::vector<int> b) {
int n = R.size() + b.size();
vector<int> mg(n);
vector<ll> dp[3];
dp[0] = dp[1] = dp[2] = vector<ll>(n + 1 , (ll)1e18);
merge(all(R) , all(b) , mg.begin());
dp[0][0] = 0;
int last = 0;
auto Tp = [&](int id) -> bool {
return binary_search(all(R) , mg[id]);
};
auto solve = [&](int l , int r) {
rep(X , 0 , 3)
rep(Y , 0 , 3) {
if (l == 0 && X) continue;
if (r == n && Y) continue;
if (!X && !Y) continue;
ll local = dp[X][l];
rep(i , l , r) {
if (!X) {
if (Y == 1) {
local += mg[r] - mg[i];
}
else {
if (r - l == 1) local += mg[r] - mg[r - 1];
if (i != r - 1)
local += mg[r] - mg[i];
}
}
else if (X == 1) {
if (!Y) {
if (i > l)
local += mg[i] - mg[l - 1];
}
else if (Y == 1) {
if (i == r - 1)
local += mg[r] - mg[r - 1];
if (i > l && i < r - 1)
local += min(mg[r] - mg[i] , mg[i] - mg[l - 1]);
}
else {
if (r - l == 1)
local += mg[r] - mg[r - 1];
if (i < r - 1) {
if (i == r - 2)
local += mg[r] - mg[r - 2];
if (i > l && i < r - 2)
local += min(mg[r] - mg[i] , mg[i] - mg[l - 1]);
}
}
}
else {
if (!Y) {
if (r - l == 1) local += mg[l] - mg[l - 1];
if (i > l)
local += mg[i] - mg[l - 1];
}
else if (Y == 1) {
if (i == r - 1) local += mg[r] - mg[r - 1];
if (r - l == 1) local += mg[l] - mg[l - 1];
if (i == l + 1) local += mg[l + 1] - mg[l - 1];
if (i > l + 1 && i < r - 1)
local += min(mg[r] - mg[i] , mg[i] - mg[l - 1]);
}
else {
if (r - l == 1) {
local += mg[r] - mg[r - 1];
local += mg[l] - mg[l - 1];
}
if (i == l + 1)
local += mg[l + 1] - mg[l - 1];
if (i == r - 2)
local += mg[r] - mg[r - 2];
if (i > l + 1 && r < r - 1)
local += min(mg[r] - mg[i] , mg[i] - mg[l - 1]);
}
}
}
dp[Y][r] = min(dp[Y][r] , local);
}
last = r;
};
rep(i , 0 , n)
if (last < i && Tp(last) != Tp(i)) {
solve(last , i);
}
solve(last , n);
return dp[0][n];
}
컴파일 시 표준 에러 (stderr) 메시지
wiring.cpp: In lambda function:
wiring.cpp:91:33: warning: assuming signed overflow does not occur when assuming that (X - c) > X is always false [-Wstrict-overflow]
if (i > l + 1 && r < r - 1)
^
# | 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... |