結果
問題 |
No.2786 RMQ on Grid Path
|
ユーザー |
![]() |
提出日時 | 2024-06-14 22:35:16 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
TLE
|
実行時間 | - |
コード長 | 3,350 bytes |
コンパイル時間 | 1,609 ms |
コンパイル使用メモリ | 99,392 KB |
最終ジャッジ日時 | 2025-02-21 22:13:06 |
ジャッジサーバーID (参考情報) |
judge2 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 10 TLE * 1 -- * 24 |
ソースコード
#include <iostream> #include <vector> #include <set> #include <queue> #include <algorithm> #include <cassert> using namespace std; class DSU { public: int n; vector<int> parent_or_size; DSU(int N) { n = N; parent_or_size.resize(N, -1); } int leader(int a) { assert(0 <= a && a < n); if (parent_or_size[a] < 0) { return a; } return parent_or_size[a] = leader(parent_or_size[a]); } int merge(int a, int b) { assert(0 <= a && a < n); assert(0 <= b && b < n); int x = leader(a); int y = leader(b); if (x == y) { return x; } if (-parent_or_size[x] < -parent_or_size[y]) { swap(x, y); } parent_or_size[x] += parent_or_size[y]; parent_or_size[y] = x; return x; } bool same(int a, int b) { assert(0 <= a && a < n); assert(0 <= b && b < n); return leader(a) == leader(b); } int size(int a) { assert(0 <= a && a < n); return -parent_or_size[leader(a)]; } vector<vector<int>> groups() { vector<int> leader_buf(n); vector<int> group_size(n, 0); for (int i = 0; i < n; ++i) { leader_buf[i] = leader(i); ++group_size[leader_buf[i]]; } vector<vector<int>> result(n); for (int i = 0; i < n; ++i) { result[leader_buf[i]].push_back(i); } vector<vector<int>> result2; for (int i = 0; i < n; ++i) { if (!result[i].empty()) { result2.push_back(result[i]); } } return result2; } }; int main() { int H, W; cin >> H >> W; vector<vector<int>> A(H, vector<int>(W)); for (int i = 0; i < H; ++i) { for (int j = 0; j < W; ++j) { cin >> A[i][j]; } } set<int> C; vector<pair<int, int>> q; int Q; cin >> Q; for (int i = 0; i < Q; ++i) { int a, b, c, d; cin >> a >> b >> c >> d; q.push_back({(a - 1) * W + (b - 1), (c - 1) * W + (d - 1)}); C.insert(i); } vector<vector<pair<int, int>>> L(H * W + 1); for (int i = 0; i < H; ++i) { for (int j = 0; j < W; ++j) { if (i < H - 1) { int x = A[i][j]; int y = A[i + 1][j]; int z = max(x, y); L[z].push_back({i * W + j, (i + 1) * W + j}); } if (j < W - 1) { int x = A[i][j]; int y = A[i][j + 1]; int z = max(x, y); L[z].push_back({i * W + j, i * W + j + 1}); } } } vector<int> result(Q, 0); DSU Z(H * W); for (int x = 1; x <= H * W; ++x) { if (L[x].empty()) continue; for (auto& B : L[x]) { int pos1 = B.first, pos2 = B.second; Z.merge(pos1, pos2); } vector<int> l; for (int k : C) { int p1 = q[k].first, p2 = q[k].second; if (Z.same(p1, p2)) { l.push_back(k); result[k] = x; } } for (int k : l) { C.erase(k); } } for (int i = 0; i < Q; ++i) { cout << result[i] << endl; } return 0; }