Submission #989109

#TimeUsernameProblemLanguageResultExecution timeMemory
989109aykhnBitaro’s Party (JOI18_bitaro)C++17
0 / 100
15 ms16648 KiB
#include <bits/stdc++.h> using namespace std; #define int long long #define inf 0x3F3F3F3F3F3F3F3F const int MXN = 1e5 + 5; const int B = 350; int n, m, q; vector<int> adj[MXN]; int used[MXN], dp[MXN], inq[MXN]; vector<array<int, 2>> b[MXN]; vector<int> o; void init(int a) { used[a] = 1; b[a].push_back({0, a}); set<int> in; vector<array<int, 2>> nw; for (int v : adj[a]) { if (!used[v]) init(v); in.clear(); nw.clear(); int i = 0, j = 0; while (nw.size() < B + 1 && i < b[a].size() && j < b[v].size()) { if (in.find(b[a][i][1]) != in.end()) { i++; continue; } if (in.find(b[v][j][1]) != in.end()) { j++; continue; } if (b[a][i][0] > b[v][j][0] + 1) nw.push_back(b[a][i]), in.insert(b[a][i++][1]); else nw.push_back({b[v][j][0] + 1, b[v][j][1]}), in.insert(b[v][j++][1]); } while (nw.size() < B + 1 && i < b[a].size()) if (in.find(b[a][i][1]) != in.end() && ++i) continue; else nw.push_back(b[a][i]), in.insert(b[a][i++][1]); while (nw.size() < B + 1 && j < b[v].size()) if (in.find(b[v][j][1]) != in.end() && ++j) continue; else nw.push_back({b[v][j][0] + 1, b[v][j][1]}), in.insert(b[v][j++][1]); swap(nw, b[a]); } } void dfs(int a) { used[a] = 1; for (int v : adj[a]) { if (used[v]) continue; dfs(v); } o.push_back(a); } void _() { cin >> n >> m >> q; for (int i = 0; i < m; i++) { int u, v; cin >> u >> v; adj[v].push_back(u); } for (int i = n; i >= 1; i--) { if (!used[i]) init(i); } while (q--) { int t, sz; cin >> t >> sz; vector<int> v(sz); for (int &i : v) cin >> i, inq[i] = 1; if (sz > B) { assert(0); o.clear(); for (int i = 1; i <= n; i++) used[i] = 0, dp[i] = 0; dfs(t); reverse(o.begin(), o.end()); int res = -1; for (int i : o) { if (!inq[i]) res = max(res, dp[i]); for (int j : adj[i]) dp[j] = max(dp[j], dp[i] + 1); } cout << res << '\n'; } else { int res = -1; for (array<int, 2> &i : b[t]) { if (!inq[i[1]]) { res = i[0]; break; } } cout << res << '\n'; } for (int &i : v) inq[i] = 0; } } signed main() { ios_base::sync_with_stdio(0); cin.tie(0); int t = 1; // cin >> t; for (int tt = 1; tt <= t; tt++) { _(); } }

Compilation message (stderr)

bitaro.cpp: In function 'void init(long long int)':
bitaro.cpp:29:39: warning: comparison of integer expressions of different signedness: 'long long int' and 'std::vector<std::array<long long int, 2> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   29 |         while (nw.size() < B + 1 && i < b[a].size() && j < b[v].size())
      |                                     ~~^~~~~~~~~~~~~
bitaro.cpp:29:58: warning: comparison of integer expressions of different signedness: 'long long int' and 'std::vector<std::array<long long int, 2> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   29 |         while (nw.size() < B + 1 && i < b[a].size() && j < b[v].size())
      |                                                        ~~^~~~~~~~~~~~~
bitaro.cpp:44:39: warning: comparison of integer expressions of different signedness: 'long long int' and 'std::vector<std::array<long long int, 2> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   44 |         while (nw.size() < B + 1 && i < b[a].size()) if (in.find(b[a][i][1]) != in.end() && ++i) continue; else nw.push_back(b[a][i]), in.insert(b[a][i++][1]);
      |                                     ~~^~~~~~~~~~~~~
bitaro.cpp:45:39: warning: comparison of integer expressions of different signedness: 'long long int' and 'std::vector<std::array<long long int, 2> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   45 |         while (nw.size() < B + 1 && j < b[v].size()) if (in.find(b[v][j][1]) != in.end() && ++j) continue; else nw.push_back({b[v][j][0] + 1, b[v][j][1]}), in.insert(b[v][j++][1]);
      |                                     ~~^~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...