# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
566770 | milisav | Bitaro’s Party (JOI18_bitaro) | C++14 | 1190 ms | 140900 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include<bits/stdc++.h>
#define maxn 300000
#define blk 150
using namespace std;
int n,m,q;
vector<int> a[maxn];
vector<int> b[maxn];
int city[maxn][blk];
int dist[maxn][blk];
int it[maxn];
int sz[maxn];
int c[maxn];
int ch[maxn];
bool fnd[maxn];
vector<int> topo;
priority_queue<pair<int,int> > pq;
bool ok[maxn];
void calc_small() {
for(int iter=0;iter<n;iter++) {
int u=topo[iter];
pq.push({0,u});
for(int i=0;i<b[u].size();i++) {
it[b[u][i]]=0;
pq.push({1+dist[b[u][i]][it[b[u][i]]],b[u][i]});
}
while(sz[u]<blk && !pq.empty()) {
int d=pq.top().first;
int nd=pq.top().second;
pq.pop();
int v=u;
if(nd!=u) {
v=city[nd][it[nd]];
it[nd]++;
if(it[nd]<sz[nd]) pq.push({1+dist[nd][it[nd]],nd});
}
if(!fnd[v]) {
fnd[v]=true;
dist[u][sz[u]]=d;
city[u][sz[u]]=v;
sz[u]++;
}
}
while(!pq.empty()) pq.pop();
for(int i=0;i<sz[u];i++) fnd[city[u][i]]=false;
}
}
int dst[maxn];
int calc_big(int t) {
for(int i=1;i<=n;i++) dst[i]=-1;
for(int iter=0;iter<n;iter++) {
int u=topo[iter];
if(ok[u]) dst[u]=0;
for(auto v:b[u]) {
if(dst[v]!=-1) dst[u]=max(dst[u],dst[v]+1);
}
if(u==t) return dst[u];
}
return -1;
}
int main() {
scanf("%d %d %d",&n,&m,&q);
for(int i=0;i<m;i++) {
int s,e;
scanf("%d %d",&s,&e);
a[s].push_back(e);
b[e].push_back(s);
ch[e]++;
}
for(int i=1;i<=n;i++) {
ok[i]=true;
if(ch[i]==0) topo.push_back(i);
}
int iter=0;
while(iter<topo.size()) {
int u=topo[iter];
for(auto v:a[u]) {
ch[v]--;
if(ch[v]==0) topo.push_back(v);
}
iter++;
}
calc_small();
/*for(int i=1;i<=n;i++) {
printf("%d %d\n",i,sz[i]);
for(int j=0;j<sz[i];j++) {
printf("\t%d %d\n",city[i][j],dist[i][j]);
}
}*/
for(int i=0;i<q;i++) {
int t,y;
scanf("%d %d",&t,&y);
for(int j=0;j<y;j++) {
scanf("%d",&c[j]);
ok[c[j]]=false;
}
if(y<blk) {
int ans=-1;
for(int j=0;j<sz[t];j++) {
if(ok[city[t][j]]) {
ans=dist[t][j];
break;
}
}
printf("%d\n",ans);
}
else {
printf("%d\n",calc_big(t));
}
for(int j=0;j<y;j++) {
ok[c[j]]=true;
}
}
return 0;
}
컴파일 시 표준 에러 (stderr) 메시지
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |