Submission #675018

#TimeUsernameProblemLanguageResultExecution timeMemory
675018QwertyPiI want to be the very best too! (NOI17_pokemonmaster)C++14
Compilation error
0 ms0 KiB
#include <bits/stdc++.h> #define fi first #define se second using namespace std; const int MAXN = 5e4 + 11, MAXQ = 1e5 + 11; const int SQ = 1000; int l[MAXN], p[MAXN], tp[MAXN]; int ans[MAXQ]; struct DSU{ int dsu[MAXN]; map<int, int> info[MAXN]; void init(int n){ for(int i = 0; i < n; i++) dsu[i] = i; for(int i = 0; i < n; i++) info[i].clear(), info[i][p[i]]++; } int f(int x){ return dsu[x] == x ? x : dsu[x] = f(dsu[x]); } void g(int x, int y){ x = f(x), y = f(y); if(x == y) return; if(info[x].size() < info[y].size()) swap(x, y); for(auto i : info[y]) info[x][i.fi] += i.se; dsu[y] = x; } } dsu; struct qry{ int t, x, y, v, i; }; struct edge{ int u, v, w; bool operator< (const edge& o) const { return w < o.w; } }; int n, m, q; pair<int, int> change[MAXQ]; vector<edge> E; int eid = 0; void solve(vector<qry> Q){ eid = 0; int _l = Q[0].i; dsu.init(n * m); for(int i = 0; i < n * m; i++) tp[i] = p[i]; for(auto q : Q){ if(q.t == 1){ change[q.i] = {tp[q.x * m + q.y], q.v}; tp[q.x * m + q.y] = q.v; } } vector<pair<int, int>> Q2; for(auto q : Q){ if(q.t == 2){ Q2.push_back({q.v, q.i}); } } sort(Q2.begin(), Q2.end()); for(int j = 0; j < Q2.size(); j++){ while(eid < E.size() && E[eid].w <= Q2[j].fi) dsu.g(E[eid].u, E[eid].v), eid++; int i = Q2[j].se, ri = i - _l; int pos = dsu.f(Q[ri].x * m + Q[ri].y); for(int k = 0; k < ri; k++){ if(Q[k].t == 1){ if(dsu.f(Q[k].x * m + Q[k].y) != pos) continue; dsu.info[pos][change[_l + k].fi]--; if(dsu.info[pos][change[_l + k].fi] == 0) dsu.info[pos].erase(change[_l + k].fi); dsu.info[pos][change[_l + k].se]++; } } if(l[Q[ri].x * m + Q[ri].y] <= Q[ri].v){ // ans[i] = dsu.info[pos].size(); for(auto i : dsu.info[pos]){ ans[i] += (i.se > 0); } } for(int k = 0; k < ri; k++){ if(Q[k].t == 1){ if(dsu.f(Q[k].x * m + Q[k].y) != pos) continue; dsu.info[pos][change[_l + k].se]--; if(dsu.info[pos][change[_l + k].se] == 0) dsu.info[pos].erase(change[_l + k].se); dsu.info[pos][change[_l + k].fi]++; } } } } int32_t main(){ cin >> n >> m >> q; for(int i = 0; i < n; i++){ for(int j = 0; j < m; j++){ cin >> l[i * m + j]; } } for(int i = 0; i < n; i++){ for(int j = 0; j < m - 1; j++){ int u = i * m + j, v = i * m + j + 1; E.push_back({u, v, max(l[u], l[v])}); } } for(int i = 0; i < n - 1; i++){ for(int j = 0; j < m; j++){ int u = i * m + j, v = (i + 1) * m + j; E.push_back({u, v, max(l[u], l[v])}); } } sort(E.begin(), E.end()); for(int i = 0; i < n; i++){ for(int j = 0; j < m; j++){ cin >> p[i * m + j]; } } for(int i = 0; i < q; i += SQ){ vector<qry> Q; for(int j = i; j < min(i + SQ, q); j++){ int t, x, y, v; cin >> t >> y >> x >> v; x--; y--; Q.push_back({t, x, y, v, j}); } solve(Q); for(auto q : Q){ if(q.t == 1) p[q.x * m + q.y] = q.v; } for(int j = i; j < min(i + SQ, q); j++){ if(Q[j - i].t == 2){ cout << ans[j] << endl; } } } }

Compilation message (stderr)

pokemonmaster.cpp: In function 'void solve(std::vector<qry>)':
pokemonmaster.cpp:61:19: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::pair<int, int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   61 |  for(int j = 0; j < Q2.size(); j++){
      |                 ~~^~~~~~~~~~~
pokemonmaster.cpp:62:13: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<edge>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   62 |   while(eid < E.size() && E[eid].w <= Q2[j].fi) dsu.g(E[eid].u, E[eid].v), eid++;
      |         ~~~~^~~~~~~~~~
pokemonmaster.cpp:76:8: error: no match for 'operator[]' (operand types are 'int [100011]' and 'std::pair<const int, int>')
   76 |     ans[i] += (i.se > 0);
      |        ^