Submission #342218

#TimeUsernameProblemLanguageResultExecution timeMemory
342218borderBitaro’s Party (JOI18_bitaro)C++17
7 / 100
2087 ms14532 KiB
#include <bits/stdc++.h> using namespace std; typedef long long ll; const int N = 100010; const int B = 315; int n, m, q, d[N], b[N]; bool vis[N], busy[N]; vector<int> adj[N], rev[N]; vector<pair<int, int>> f[N]; void precompute() { for (int i = 1; i <= n; ++i) { vector<pair<int, int>> tmp; for (auto v: rev[i]) { for (auto x: f[v]) { tmp.push_back({x.first+1, x.second}); } } tmp.push_back({0, i}); sort(tmp.begin(), tmp.end(), greater<pair<int, int>>()); for (auto x: tmp) { if (!vis[x.second]) { vis[x.second] = true; f[i].push_back(x); if (f[i].size() == B) break; } } for (auto p: f[i]) vis[p.second] = false; } } int solve(int source) { int ans = -1; for (auto x: f[source]) { if (!busy[x.second]) { ans = max(ans, x.first); } } return ans; } int brute(int source) { for (int i = 1; i <= n; ++i) d[i] = INT_MIN; d[source] = 0; for (int i = source-1; i >= 1; --i) { for (auto v: adj[i]) { d[i] = max(d[i], d[v] + 1); } } int ans = -1; for (int i = 1; i <= source; ++i) { if (!busy[i]) ans = max(ans, d[i]); } return ans; } int main() { scanf("%d%d%d", &n, &m, &q); for (int i = 1; i <= m; ++i) { int u, v; scanf("%d%d", &u, &v); adj[u].push_back(v); rev[v].push_back(u); } precompute(); while (q--) { int node, sz; scanf("%d%d", &node, &sz); for (int i = 1; i <= sz; ++i) { scanf("%d", &b[i]); busy[b[i]] = true; } if (sz >= B) { printf("%d\n", brute(node)); } else { printf("%d\n", solve(node)); } for (int i = 1; i <= sz; ++i) { busy[b[i]] = false; } } }

Compilation message (stderr)

bitaro.cpp: In function 'int main()':
bitaro.cpp:59:8: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   59 |   scanf("%d%d%d", &n, &m, &q);
      |   ~~~~~^~~~~~~~~~~~~~~~~~~~~~
bitaro.cpp:62:10: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   62 |     scanf("%d%d", &u, &v);
      |     ~~~~~^~~~~~~~~~~~~~~~
bitaro.cpp:70:10: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   70 |     scanf("%d%d", &node, &sz);
      |     ~~~~~^~~~~~~~~~~~~~~~~~~~
bitaro.cpp:72:12: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   72 |       scanf("%d", &b[i]);
      |       ~~~~~^~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...