Submission #127347

#TimeUsernameProblemLanguageResultExecution timeMemory
127347RockyBCoin Collecting (JOI19_ho_t4)C++17
0 / 100
2 ms376 KiB
/// In The Name Of God //#pragma GCC optimize("Ofast") //#pragma GCC target("sse,sse2,sse3,ssse3,sse4") //#pragma GCC target("sse,sse2,sse3,ssse3,sse4,popcnt,abm,mmx,avx,avx2,tune=native") //#pragma GCC optimize("unroll-loops") #include <bits/stdc++.h> #define f first #define s second #define pb push_back #define pp pop_back #define mp make_pair #define sz(x) (int)x.size() #define sqr(x) ((x) * 1ll * (x)) #define all(x) x.begin(), x.end() #define rep(i, l, r) for (int i = (l); i <= (r); i++) #define per(i, l, r) for (int i = (l); i >= (r); i--) #define Kazakhstan ios_base :: sync_with_stdio(0), cin.tie(0), cout.tie(0); #define nl '\n' #define ioi exit(0); typedef long long ll; typedef long double ld; typedef unsigned long long ull; const int N = (int)2e5 + 7; const int inf = (int)1e9 + 7; const int mod = (int)1e9 + 7; const ll linf = (ll)1e18 + 7; const int dx[] = {-1, 0, 1, 0, 1, -1, -1, 1}; const int dy[] = {0, 1, 0, -1, 1, -1, 1, -1}; using namespace std; int n; pair <ll, ll> a[N << 1]; ll dst(pair <ll, ll> x, pair <ll, ll> y) { return abs(x.f - y.f) + abs(x.s - y.s); } int cnt[N][3]; ll go1(int x, int y) { ll mn = linf; pair <int, int> go = {-1, -1}; rep(j, 1, 2) { rep(i, 1, n) { if (!cnt[i][j]) { ll cur = dst({x, y}, {i, j}); if (cur < mn) { mn = cur; go = {i, j}; } } } } cnt[go.f][go.s]++; return mn; } ll go2(int x, int y) { ll mn = linf; pair <int, int> go = {-1, -1}; per(j, 2, 1) { rep(i, 1, n) { if (!cnt[i][j]) { ll cur = dst({x, y}, {i, j}); if (cur < mn) { mn = cur; go = {i, j}; } } } } cnt[go.f][go.s]++; return mn; } ll fnd(int x, int y) { ll mn = linf; pair <int, int> go = {-1, -1}; rep(i, 1, n) { rep(j, 1, 2) { if (cnt[i][j] > 1) { ll cur = dst({i, j}, {x, y}); if (cur < mn) { mn = cur; go = {i, j}; } } } } cnt[go.f][go.s]--; return mn; } vector <int> em[3], fl[3]; ll calc(int v = 1) { if (v > n) return 0; ll res = 0; rep(j, 1, 2) { if (!cnt[v][j]) em[j].pb(v); if (cnt[v][j] > 1) fl[j].pb(v); } rep(j, 1, 2) { while (sz(em[j]) && cnt[v][j] > 1) { int p = em[j].back(); if (!cnt[p][j]) { cnt[v][j]--; cnt[p][j]++; res += v - p; em[j].pp(); } else assert(0); } /* per(p, v, 1) { if (cnt[v][j] > 1 && !cnt[p][j]) { cnt[v][j]--; cnt[p][j]++; res += v - p; } } */ } rep(j, 1, 2) { if (!cnt[v][j]) { while (sz(fl[j])) { int p = fl[j].back(); if (cnt[p][j] > 1) { res += v - p; cnt[p][j]--; cnt[v][j]++; if (cnt[p][j] == 1) fl[j].pp(); break; } else assert(0); } } } rep(j, 1, 2) { while (sz(em[3 - j]) && cnt[v][j] > 1) { int p = em[3 - j].back(); if (!cnt[p][3 - j]) { cnt[v][j]--; cnt[p][3 - j]++; res += v - p + 1; em[3 - j].pp(); } else assert(0); } /* per(p, v, 1) { if (cnt[v][j] > 1 && !cnt[p][3 - j]) { cnt[v][j]--; cnt[p][3 - j]++; res += v - p + 1; } } */ } rep(j, 1, 2) { if (!cnt[v][j]) { while (sz(fl[3 - j])) { int p = fl[3 - j].back(); if (cnt[p][3 - j] > 1) { res += v - p + 1; cnt[p][3 - j]--; cnt[v][j]++; if (cnt[p][3 - j] == 1) fl[3 - j].pp(); break; } else assert(0); } /* per(p, v, 1) { if (cnt[p][3 - j] > 1) { res += v - p + 1; cnt[p][3 - j]--; cnt[v][j]++; break; } } */ } } return res + calc(v + 1); } int main() { #ifdef IOI freopen ("in.txt", "r", stdin); freopen ("D.out", "w", stdout); #endif Kazakhstan cin >> n; rep(i, 1, n << 1) { cin >> a[i].f >> a[i].s; } sort (a + 1, a + n + n + 1); ll ans = 0; rep(i, 1, n << 1) { ll mn = linf; pair <int, int> go = {-1, -1}; rep(x, 1, n) { rep(y, 1, 2) { ll cur = dst(a[i], {x, y}); if (cur < mn) { mn = cur; go = {x, y}; } } } ans += mn; cnt[go.f][go.s]++; // cerr << a[i].f << ' ' << a[i].s << " -> " << go.f << ' ' << go.s << nl; } per(j, 2, 1) { rep(i, 1, n) { cerr << cnt[i][j] << ' '; } cerr << nl; } cerr << ans << nl; //cerr << calc() << ' ' << ans <<nl; cout << ans + calc(); per(j, 2, 1) { rep(i, 1, n) { cerr << cnt[i][j] << ' '; } cerr << nl; } cerr << ans << nl; ioi }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...