Submission #608440

#TimeUsernameProblemLanguageResultExecution timeMemory
608440amunduzbaevWiring (IOI17_wiring)C++17
0 / 100
1 ms1876 KiB
#include "bits/stdc++.h" using namespace std; #include "wiring.h" #ifndef EVAL #include "grader.cpp" #endif #define ar array typedef long long ll; const int N = 2e5 + 5; const ll inf = 2e18; ll c[N], a[N]; ll dp[N], pref[N]; ll min_total_length(vector<int> r, vector<int> b) { int n = (int)r.size(); int m = (int)b.size(); int T = n + m; reverse(r.begin(), r.end()); reverse(b.begin(), b.end()); for(int i=1;i<=T;i++){ if(r.back() < b.back()) a[i] = r.back(), r.pop_back(); else a[i] = b.back(), b.pop_back(), c[i] = 1; pref[i] = pref[i-1] + a[i]; } memset(dp, 31, sizeof dp); ar<ll, 2> last {-inf, -inf}; dp[0] = 0; c[0] = -1; set<ar<ll, 2>> L, R; ll z = 0; for(int i=1;i<=T;i++){ dp[i] = dp[i - 1] + a[i] - last[c[i] ^ 1]; if(c[i] != c[i - 1] && ~c[i - 1]){ z = i - 1; L.clear(), R.clear(); for(int j=i-2;~j;j--){ if(c[j + 1] == c[i]) break; dp[i] = min(dp[i], dp[j] + a[i] * (i - j) - pref[i] + pref[j]); if(2 * z - i <= j){ R.insert({pref[j] - a[z] * j + dp[j], j}); } else { L.insert({pref[j] - a[z + 1] * j + dp[j], j}); } } } else if(z){ if(!L.empty()){ int j = 2 * z - i; L.erase({pref[j] - a[z + 1] * j + dp[j], j}); R.insert({pref[j] - a[z] * j + dp[j], j}); } } last[c[i]] = a[i]; if(!R.empty()) dp[i] = min(dp[i], (*R.begin())[0] + pref[i] - pref[z] * 2 - a[z] * (i - 2 * z)); if(!L.empty()) dp[i] = min(dp[i], (*L.begin())[0] + pref[i] - pref[z] * 2 + a[z + 1] * (2 * z - i)); } return dp[T]; } /* 4 5 1 2 3 7 0 4 5 9 10 */
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...