Submission #256005

#TimeUsernameProblemLanguageResultExecution timeMemory
256005AM1648Bridges (APIO19_bridges)C++17
100 / 100
2263 ms4984 KiB
/* be name khoda */ // #define long_enable #include <iostream> #include <algorithm> #include <cstring> #include <numeric> #include <vector> #include <fstream> #include <set> #include <map> using namespace std; #ifdef long_enable typedef long long int ll; #else typedef int ll; #endif typedef pair<ll, ll> pii; typedef pair<pii, ll> ppi; typedef pair<ll, pii> pip; typedef vector<ll> vi; typedef vector<pii> vpii; #define forifrom(i, s, n) for (ll i = s; i < n; ++i) #define forirto(i, n, e) for (ll i = (n) - 1; i >= e; --i) #define fori(i, n) forifrom (i, 0, n) #define forir(i, n) forirto (i, n, 0) #define F first #define S second #define pb push_back #define eb emplace_back #define all(x) (x).begin(), (x).end() #define smin(a, b) a = min(a, (b)) #define smax(a, b) a = max(a, (b)) #define debug(x) cout << #x << " -> " << (x) << endl #define debug2(x, y) cout << #x << ' ' << #y << " -> " << (x) << ' ' << (y) << endl #define debug3(x, y, z) cout << #x << ' ' << #y << ' ' << #z << " -> " << (x) << ' ' << (y) << ' ' << (z) << endl #define debug4(x, y, z, t) cout << #x << ' ' << #y << ' ' << #z << ' ' << #t << " -> " << (x) << ' ' << (y) << ' ' << (z) << ' ' << (t) << endl #define debuga(x, n) cout << #x << " -> "; fori (i1_da, n) { cout << (x)[i1_da] << ' '; } cout << endl #define debugaa(x, n, m) cout << #x << " ->\n"; fori (i1_daa, n) { fori (i2_daa, m) { cout << (x)[i1_daa][i2_daa] << ' '; } cout << '\n'; } cout << endl const ll MOD = 1000000007; const ll INF = 2000000000; const long long BIG = 1446803456761533460LL; #define XL (x << 1) #define XR (XL | 1) #define MD ((l + r) >> 1) #define Add(a, b) a = ((a) + (b)) % MOD #define Mul(a, b) a = (1LL * (a) * (b)) % MOD // ----------------------------------------------------------------------- const ll maxn = 50010; const ll maxm = 100010; const ll SQ = 400; ll n, m, qn, qm, cm; pip es[maxm]; ppi qs[maxm], cs[maxm]; ll rt[maxn], sz[maxn], hist[SQ], hn, qt[maxm], es_sort[maxm], lst[maxm]; bool chg[maxm]; ll res[maxm]; ll root(ll x) { return rt[x] == x ? x : rt[x] = root(rt[x]); } ll roottmp(ll x) { return rt[x] == x ? x : roottmp(rt[x]); } void merge(ll a, ll b) { if (root(a) != root(b)) { if (sz[rt[a]] > sz[rt[b]]) swap(a, b); sz[rt[b]] += sz[rt[a]]; rt[rt[a]] = rt[b]; } } void mergetmp(ll a, ll b) { ll ra = roottmp(a), rb = roottmp(b); if (ra == rb) hist[hn++] = -1; else { if (sz[ra] > sz[rb]) swap(ra, rb); hist[hn++] = ra; sz[rb] += sz[ra]; rt[ra] = rb; } } void undo() { ll x = hist[--hn]; if (x != -1) { sz[rt[x]] -= sz[x]; rt[x] = x; } } ll search(ll s, ll w, ll t) { forir (i, cm) if (cs[i].S < t && lst[cs[i].F.F] != t + 1) { if (cs[i].F.S >= w) { auto [a, b] = es[cs[i].F.F].S; mergetmp(a, b); } lst[cs[i].F.F] = t + 1; } fori (i, cm) if (lst[cs[i].F.F] != t + 1 && es[cs[i].F.F].F >= w) { auto [a, b] = es[cs[i].F.F].S; mergetmp(a, b); } ll r = sz[roottmp(s)]; while (hn) undo(); return r; } void calc() { sort(es_sort, es_sort + m, [](const ll a, const ll b) { return es[a].F > es[b].F; }); sort(qs, qs + qm, greater<ppi>()); iota(rt, rt + n, 0); fill(sz, sz + n, 1); fori (i, cm) chg[cs[i].F.F] = 1; ll ptr = 0; fori (i, m) { if (chg[es_sort[i]]) continue; while (ptr < qm && qs[ptr].F.F > es[es_sort[i]].F) { res[qs[ptr].S] = search(qs[ptr].F.S, qs[ptr].F.F, qs[ptr].S); ++ptr; } auto [a, b] = es[es_sort[i]].S; merge(a, b); } while (ptr < qm) { res[qs[ptr].S] = search(qs[ptr].F.S, qs[ptr].F.F, qs[ptr].S); ++ptr; } fori (i, cm) { chg[cs[i].F.F] = 0; es[cs[i].F.F].F = cs[i].F.S; } qm = cm = 0; } int main() { ios_base::sync_with_stdio(false), cin.tie(0), cout.tie(0); cin >> n >> m; fori (i, m) { ll a, b, w; cin >> a >> b >> w; --a, --b; es[i] = {w, {a, b}}; } iota(es_sort, es_sort + m, 0); cin >> qn; fori (i, qn) { ll t, a, b; cin >> t >> a >> b; --a; qt[i] = t; if (t == 1) { cs[cm++] = {{a, b}, i}; } else { qs[qm++] = {{b, a}, i}; } if ((cm + 1) % SQ == 0) calc(); } calc(); fori (i, qn) if (qt[i] == 2) cout << res[i] << '\n'; }
#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...
#Verdict Execution timeMemoryGrader output
Fetching results...