Submission #907466

#TimeUsernameProblemLanguageResultExecution timeMemory
907466LOLOLOI want to be the very best too! (NOI17_pokemonmaster)C++14
0 / 100
593 ms19552 KiB
#include <bits/stdc++.h> using namespace std; typedef long long ll; #define f first #define s second #define pb push_back #define ep emplace #define eb emplace_back #define lb lower_bound #define ub upper_bound #define all(x) x.begin(), x.end() #define rall(x) x.rbegin(), x.rend() #define uniquev(v) sort(all(v)), (v).resize(unique(all(v)) - (v).begin()) #define mem(f,x) memset(f , x , sizeof(f)) #define sz(x) (int)(x).size() #define __lcm(a, b) (1ll * ((a) / __gcd((a), (b))) * (b)) #define mxx *max_element #define mnn *min_element #define cntbit(x) __builtin_popcountll(x) #define len(x) (int)(x.length()) const int M = 1e5 + 100; const int N = M; const int SZ = 340; int t[N], x[N], l[N], r[N], n, m, change[M], L[M], P[M], sz[N], p[N], C[N], ans[N]; vector <pair <int, int>> save[M]; int cov(int a, int b) { return a * (m - 1) + b; } int get(int a) { return p[a] ? get(p[a]) : a; } map <int, int> mp[N]; void unite(int a, int b) { a = get(a), b = get(b); if (a == b) return; if (sz[a] < sz[b]) swap(a, b); sz[a] += sz[b]; p[b] = a; for (auto x : mp[b]) { mp[a][x.f] += x.s; } } vector <vector <int>> action; void upd(int c, int x) { c = get(c); action.pb({c, x, mp[c][x]}); mp[c][x]++; } void rollback() { while (sz(action)) { auto t = action.back(); action.pop_back(); if (t[2] == 0) { mp[t[0]].erase(t[1]); } else { mp[t[0]][t[1]] = t[2]; } } } ll solve() { mem(L, 0x3f); mem(P, 0x3f); int q; cin >> n >> m >> q; for (int i = 1; i <= n; i++) for (int j = 1; j <= m; j++) cin >> L[cov(i, j)]; vector <vector <int>> edge; for (int i = 1; i <= n; i++) { for (int j = 1; j <= m; j++) { if (i < n) edge.pb({max(L[cov(i + 1, j)], L[cov(i, j)]), cov(i + 1, j), cov(i, j)}); if (j < m) edge.pb({max(L[cov(i, j + 1)], L[cov(i, j)]), cov(i, j + 1), cov(i, j)}); } } sort(all(edge)); for (int i = 1; i <= n; i++) for (int j = 1; j <= m; j++) cin >> P[cov(i, j)]; for (int i = 1; i <= q; i++) { cin >> t[i] >> l[i] >> x[i] >> r[i]; } for (int i = 1; i <= q; i += SZ) { int X = i, Y = min(q, i + SZ - 1); vector <int> ask, up; for (int j = X; j <= Y; j++) { if (t[j] == 2) { ask.pb(j); } else { up.pb(j); change[cov(x[j], l[j])] = 1; } } for (int j = X; j <= Y; j++) { if (t[j] == 1) { P[cov(x[j], l[j])] = r[j]; } else { save[j - X].clear(); for (auto t : up) { save[j - X].pb({cov(x[t], l[t]), P[cov(x[t], l[t])]}); } } } sort(all(ask), [&](int a, int b) { return r[a] < r[b]; }); for (int j = 1; j <= n * m; j++) { mp[j].clear(); if (change[j] == 0) mp[j][P[j]]++; sz[j] = 1; p[j] = 0; } int j = 0; for (auto id : ask) { while (j < sz(edge) && r[id] >= edge[j][0]) { unite(edge[j][1], edge[j][2]); j++; } for (auto t : save[id - X]) { upd(t.f, t.s); } if (r[id] >= L[cov(x[id], l[id])]) ans[id] = sz(mp[get(cov(x[id], l[id]))]); rollback(); } for (auto x : up) change[x] = 0; } for (int i = 1; i <= q; i++) { if (t[i] == 2) { cout << ans[i] << "\n"; } } return 0; } int main() { ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0); int t = 1; //cin >> t; while (t--) { solve(); //cout << solve() << '\n'; } return 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...
#Verdict Execution timeMemoryGrader output
Fetching results...