Submission #347319

#TimeUsernameProblemLanguageResultExecution timeMemory
347319ewwdsgfvsdBitaro’s Party (JOI18_bitaro)C++17
14 / 100
2114 ms225916 KiB
#include <bits/stdc++.h> /*#pragma comment(linker, "/stack:200000000") #pragma GCC optimize("Ofast") #pragma GCC target("sse,sse2,sse3,ssse3,sse4,popcnt,abm,mmx,avx,tune=native")*/ #pragma GCC optimize("O2") #pragma GCC optimize("unroll-loops") #pragma GCC target("avx,avx2,sse,sse2,fma") using namespace std; using ll = /*long long*/ int; #define F first #define S second #define pb push_back #define lc v<<1 #define rc 1+(v<<1) #define fast_io ios::sync_with_stdio(false);cin.tie(nullptr);cout.tie(nullptr); const int N=1e5+10,LN=20,M=1e5+10,SQ=200,inf=1e9; const ll INF=1e18; const int MOD=1000000007 /*998244353*/; #include <ext/pb_ds/assoc_container.hpp> #include <ext/pb_ds/tree_policy.hpp> using namespace __gnu_pbds; using pll=pair<ll,ll>; using pii=pair<int,int>; #define ordered_set tree<pll, null_type,less<pll>, rb_tree_tag,tree_order_statistics_node_update> ll pow(ll x, ll y, ll mod){ ll ans=1; while (y != 0) { if (y & 1) ans = ans * x % mod; y >>= 1; x = x * x % mod; } return ans; } ll n,m,q; bool g[N]; vector<pll> d[N]; vector<ll> adj[N]; int main(){ fast_io; cin >> n >> m >> q; for(ll i=1; i<=m; i++){ ll v,u; cin >> v >> u; adj[u].pb(v); } for(ll i=1; i<=n; i++){ d[i].pb({0,i}); ll k=1; for(ll j : adj[i]){ for(pll p : d[j]) d[i].pb({p.F-1,p.S}); inplace_merge(d[i].begin(),d[i].begin()+k,d[i].end()); vector<pll> v; for(pll p : d[i]) if(!g[p.S]) v.pb(p),g[p.S]=1; for(pll p : v) g[p.S]=0; swap(v,d[i]); k=d[i].size(); k=min(k,SQ); d[i].resize(k); } } for(ll i=1; i<=n; i++) d[i].pb({1,0}); while(q--){ ll v,k; set<ll> t; cin >> v >> k; for(ll i=0; i<k; i++){ ll u; cin >> u; t.insert(u); } if(k<SQ){ for(pll p : d[v]){ if(t.find(p.S)==t.end()){ cout << -p.F << '\n'; break; } } }else{ ll f[N]; for(ll i=1; i<=n; i++){ if(t.find(i)==t.end()){ f[i]=0; }else f[i]=-1; for(ll j : adj[i]) if(f[j]!=-1) f[i]=max(f[i],f[j]+1); } cout << f[v] << '\n'; } } return 0; }

Compilation message (stderr)

bitaro.cpp:17:14: warning: overflow in conversion from 'double' to 'll' {aka 'int'} changes value from '1.0e+18' to '2147483647' [-Woverflow]
   17 | const ll INF=1e18;
      |              ^~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...