0%

2025牛客暑期多校训练营1—K.Museum Acceptance(分层图,把一个点分为多个点)

思路讲解

非常暴力的模拟,唯一记忆的地方就在于这个划线。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
FOR(i,1,N){
if(ans[i][1]!=0){
cout<<ans[i][1]<<"\n";
continue;
}
ll cur=i,id=1;
vector<arr2> wp;
while(true){
wp.pb({cur,id});
ll v=g[cur][id];
FOR(i,1,num[v]){
if(g[v][i]==cur){
id=i;
}
}
if(id+1<=num[v]){
id+=1;
}else{
id=1;
}
if(ans[v][id]){
ll lans=ans[v][id]+SZ(st);
if(ans[v][id]==-1) lans=SZ(st);
for(auto &[x,idx]:wp){
ans[x][idx]=lans;
}
break;
}
ans[v][id]=-1;
arr2 t={cur,v};sort(all(t));
st.insert(t);
cur=v;
}
cout<<ans[i][1]<<"\n";
st.clear();
}

AC代码

https://ac.nowcoder.com/acm/contest/view-submission?submissionId=78205559

心路历程(WA,TLE,MLE……)