Submission #654606

#TimeUsernameProblemLanguageResultExecution timeMemory
654606bebraPictionary (COCI18_pictionary)C++17
14 / 140
268 ms35868 KiB
#include <bits/stdc++.h> using namespace std; #define dbg(x) cerr << #x << ": " << x << endl; const int MAX_N = 1e5 + 5; const int MAX_Q = 1e5 + 5; vector<pair<int, int>> queries[MAX_N]; int ans[MAX_Q]; struct DisjointSetUnion { vector<int> parent; vector<unordered_set<int>> sets; vector<int> size; DisjointSetUnion(int n) { parent.resize(n); sets.resize(n); size.resize(n); for (int i = 0; i < n; ++i) { parent[i] = i; sets[i].insert(i); size[i] = queries[i].size() + 1; } } int find(int v) const { return parent[v]; } void unite(int u, int v, int days_n) { u = find(u); v = find(v); if (u == v) return; if (size[u] > size[v]) { swap(u, v); } size[v] += sets[u].size(); for (auto x : sets[u]) { vector<pair<int, int>> keep; for (auto [y, idx] : queries[x]) { if (find(y) == v) { ans[idx] = min(ans[idx], days_n); --size[v]; } else if (find(y) != u) { keep.emplace_back(y, idx); } } swap(queries[x], keep); size[v] += keep.size(); parent[x] = v; sets[v].insert(x); } } }; int main() { ios_base::sync_with_stdio(false); cin.tie(nullptr); int n, m, q; cin >> n >> m >> q; for (int i = 0; i < q; ++i) { int u, v; cin >> u >> v; queries[u].emplace_back(v, i); queries[v].emplace_back(u, i); } DisjointSetUnion dsu(n + 5); fill_n(ans, n, 1e9); for (int g = m; g >= 1; --g) { int u = g; for (int v = 2 * g; v <= n; v += g) { dsu.unite(u, v, m - g + 1); u = v; } } for (int i = 0; i < q; ++i) { assert(ans[i] != 1e9); cout << ans[i] << '\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...
#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...