Submission #503660

#TimeUsernameProblemLanguageResultExecution timeMemory
503660amunduzbaevCollapse (JOI18_collapse)C++14
0 / 100
513 ms20804 KiB
#include "collapse.h" #include "bits/stdc++.h" using namespace std; #ifndef EVAL #include "grader.cpp" #endif #define ar array namespace First{ struct node{ int l, r, a, b; }; struct DSU{ vector<int> par, sz; int n; vector<ar<int, 2>> last; void init(int N){ n = N; par.resize(n), sz.resize(n); for(int i=0;i<n;i++) par[i] = i, sz[i] = 1; } int f(int x){ return (par[x] == x ? x : f(par[x])); } void merge(int a, int b){ a = f(a), b = f(b); if(a == b) return; if(sz[a] < sz[b]) swap(a, b); par[b] = a, sz[a] += sz[b]; last.push_back({a, b}), n--; } void roll_back(int m){ while((int)last.size() > m){ int a = last.back()[0], b = last.back()[1]; last.pop_back(); par[b] = b, sz[a] -= sz[b]; n++; } } }; vector<int> solve(int n, vector<int> t, vector<int> a, vector<int> b, vector<int> in, vector<int> p){ int P = p[0]; int q = in.size(), m = a.size(); map<ar<int, 2>, int> mm; vector<node> edges; for(int i=0;i<m;i++){ if(a[i] > b[i]) swap(a[i], b[i]); if(a[i] <= P && P < b[i]) continue; if(t[i] == 0){ mm[{a[i], b[i]}] = i; } else { edges.push_back({mm[{a[i], b[i]}], i - 1, a[i], b[i]}); mm.erase({a[i], b[i]}); } } for(auto x : mm){ edges.push_back({x.second, m - 1, x.first[0], x.first[1]}); } for(int i=0;i<q;i++){ edges.push_back({in[i], in[i], -1, i}); } vector<int> res(q); DSU dsu; dsu.init(n); function<void(int, int, vector<node>)> go = [&](int l, int r, vector<node> qq){ int m = dsu.last.size(); if(l == r){ for(auto x : qq){ if(~x.a){ // edges if(x.l <= l && l <= x.r) dsu.merge(x.a, x.b); } else { // query res[x.b] = dsu.n; } } dsu.roll_back(m); return; } vector<node> q2; for(auto x : qq){ if(~x.a){ if(x.l <= l && r <= x.r) dsu.merge(x.a, x.b); else if(max(x.l, l) <= min(x.r, r)) q2.push_back(x); } else { q2.push_back(x); } } int mid = (l + r) >> 1; go(l, mid, q2); go(mid + 1, r, q2); dsu.roll_back(m); }; go(0, m - 1, edges); return res; } } namespace Second{ vector<int> solve(int n, vector<int> t, vector<int> a, vector<int> b, vector<int> in, vector<int> p){ assert(0); } } vector<int> simulateCollapse( int n, vector<int> t, vector<int> a, vector<int> b, vector<int> in, vector<int> p) { if(*max_element(p.begin(), p.end()) == *min_element(p.begin(), p.end())){ return First::solve(n, t, a, b, in, p); } if(*max_element(t.begin(), t.end()) == 0){ return Second::solve(n, t, a, b, in, p); } assert(0); }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...