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>
#define int int64_t
#define vi vector<int>
#define vvi vector<vi>
#define vb vector<bool>
#define vvb vector<vb>
#define ii pair<int, int>
#define x first
#define y second
#define vii vector<ii>
#define pb push_back
#define all(x) x.begin(), x.end()
#define loop(i,s,e) for(int i=s;i<e;++i)
#define chkmin(a,b) a = min(a,b)
#define chkmax(a,b) a = max(a,b)
using namespace std;
const int INF = 2e18;
int min_total_length(vector<int32_t> r, vector<int32_t> b){
vi cur, last;
vi vals, lvals(1,0), v1, v2;
int i = 0, j = 0, n = r.size(), m = b.size();
auto get = [&](){
int who = 0;
if (i==n || (j!=m && r[i]>b[j])) who = 1;
if (i==n && j==m) who = -1;
return who;
};
int lastp = 0;
while(i<n || j<m){
bool who = get();
int nextp = 0;
while(1){
if (who) cur.pb(b[j++]);
else cur.pb(r[i++]);
if (who!=get()) {
if (who && i<n) nextp = r[i];
if (!who && j<m) nextp = b[j];
break;
}
}
int mm = last.size(), nn = cur.size();
vals.resize(nn+1, INF); vals[0] = lvals[0];
//cout<<"HI: "<<i<<" "<<j<<endl;
if (mm){
int prefa = 0, prefb = 0;
loop(k,0,nn){
prefa+=cur[k]-lastp; prefb+=cur[k]-cur[0];
int dif = i-mm;
chkmin(vals[k+1], prefa + v1[min(k, mm-1)]);
if (i<mm) chkmin(vals[k+1], prefb + v2[k]);
}
}
reverse(all(cur)); reverse(all(vals));
lastp = cur[0];
loop(k,1,nn) cur[k]+=cur[k-1];
v2 = v1 = cur;
loop(k,0,nn) v1[k]=-cur[k] + (k+1)*lastp + vals[k+1];
loop(k,0,nn) v2[k]=-cur[k] + (k+1)*nextp + vals[k+1];
loop(k,1,nn) chkmin(v1[k], v1[k-1]);
loop(k,1,nn) chkmin(v2[nn-k-1], v2[nn-k]);
last = cur; cur.clear();
lvals = vals; vals.clear();
}
return lvals[0];
}
/*
clear
g++ b.cpp grader.cpp -o c ; ./c
4 5
1 2 3 7
0 4 5 9 10
*/
Compilation message (stderr)
wiring.cpp: In function 'int64_t min_total_length(std::vector<int>, std::vector<int>)':
wiring.cpp:50:21: warning: unused variable 'dif' [-Wunused-variable]
50 | int dif = i-mm;
| ^~~
# | 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... |