이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include<bits/stdc++.h>
using namespace std;
#define all(fl) fl.begin(),fl.end()
#define pb push_back
#define fi first
#define se second
#define for1(i,j,k) for(int i=j;i<=k;i++)
#define for2(i,j,k) for(int i=j;i>=k;i--)
#define for3(i,j,k,l) for(int i=j;i<=k;i+=l)
#define lb lower_bound
#define ub upper_bound
#define sz(a) (int)a.size()
#define pii pair<int,int>
#define pli pair<long long,int>
#define gcd __gcd
#define lcm(x,y) x*y/__gcd(x,y)
#define pil pair<int,long long>
const int maxn=1e5+9;
vector<int>a[maxn];
vector<pii>b[maxn];
bool blk[maxn];
int f[maxn];
int n,m;
int brute(int u,vector<int> &block){
for1(i,1,n){
blk[i]=0;
}
for (auto v:block)blk[v]=1;
for1(i,1,u){
f[i]=0;
if (blk[i])f[i]=-2*n-1;
for (auto v:a[i]){
f[i]=max(f[i],f[v]+1);
}
}
if (f[u]<0)f[u]=-1;
return f[u];
}
const int block=150;
vector<pii> merge(vector<pii> p, vector<pii> q){
vector<pii>r;
reverse(all(p));
reverse(all(q));
for (auto &v:q){
v.se++;
}
while (!p.empty()&&!q.empty()){
if (sz(r)==block)return r;
auto u=p.back(),v=q.back();
if (u.fi==v.fi&&u.se==v.se){
r.pb(u);
p.pop_back();
q.pop_back();
continue;
}
if (u.fi==v.fi){
if (u.se>=v.se){
r.pb(u);
p.pop_back();
q.pop_back();
}
else {
r.pb(v);
p.pop_back();
q.pop_back();
}
continue;
}
if (u.se>v.se){
r.pb(u);
p.pop_back();
}
else {
r.pb(v);
q.pop_back();
}
}
while (sz(r)>block)r.pop_back();
while (!p.empty()){
if (sz(r)==block)return r;
r.pb(p.back());
p.pop_back();
}
while (!q.empty()){
if (sz(r)==block)return r;
r.pb(q.back());
q.pop_back();
}
return r;
}
void solve(){
for1(i,1,n){
b[i].pb({i,0});
for (auto u:a[i]){
b[i]=merge(b[i],b[u]);
}
}
}
bool use[maxn];
signed main(){
ios_base::sync_with_stdio(0);
cin.tie(0);
//freopen("temp.INP","r",stdin);
//freopen("temp.OUT","w",stdout);
int q;
cin>>n>>m>>q;
for1(i,1,m){
int u,v;
cin>>u>>v;
a[v].pb(u);
}
solve();
//cout<<sz(b[1])<<'\n';
/*cout<<'\n';
for (auto v:b[5]){
cout<<v.fi<<" "<<v.se<<'\n';
}*/
for1(i,1,q){
int x,y;
cin>>x>>y;
vector<int>blocked;
for1(j,1,y){
int x1;
cin>>x1;
blocked.pb(x1);
}
if (y>block){
cout<<brute(x,blocked)<<'\n';
}
else {
for (auto v:blocked){
use[v]=1;
}
int ans=-1;
for(auto v:b[x]){
if (!use[v.fi]){
ans=max(ans,v.se);
}
}
cout<<ans<<'\n';
}
for (auto v:blocked){
use[v]=0;
}
}
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |