Submission #16316

#TimeUsernameProblemLanguageResultExecution timeMemory
16316khsoo01Tropical Garden (IOI11_garden)C++98
49 / 100
5048 ms11688 KiB
#include<bits/stdc++.h> #include "garden.h" #include "gardenlib.h" #define INF 0x7fffffff using namespace std; vector<int>cg[150005],cn[150005]; int n,m,p,ed[150005][2],cur,flag,vis[150005],cnt; bool state; struct destination { int dist[150005],cyc_len=0; bool in_cyc=false; }d[2]; void find_cyc(int idx) { if(vis[idx]==1) { if(!d[state].in_cyc && idx!=cn[p][state]) return; d[state].in_cyc=true; d[state].cyc_len++; } if(vis[idx]==2) return; vis[idx]++; find_cyc(cn[ed[idx][1]][(cg[ed[idx][1]][0]==ed[idx][0] && cg[ed[idx][1]].size()>1)?1:0]); vis[idx]=0; } void find_dist(int idx) { if(idx==cn[p][state]) { d[state].dist[cur]=0; return; } if(vis[idx]) { d[state].dist[cur]=-INF; return; } vis[idx]++; find_dist(cn[ed[idx][1]][(cg[ed[idx][1]][0]==ed[idx][0] && cg[ed[idx][1]].size()>1)?1:0]); vis[idx]=0; d[state].dist[cur]++; } void count_routes(int N, int M, int P, int R[][2], int Q, int G[]) { int i,j,k; n=N; m=M; p=P; for(i=0;i<m;i++) { ed[i][0]=R[i][0]; ed[i][1]=R[i][1]; ed[i+m][0]=R[i][1]; ed[i+m][1]=R[i][0]; cg[ed[i][0]].push_back(ed[i][1]); cn[ed[i][0]].push_back(i); cg[ed[i][1]].push_back(ed[i][0]); cn[ed[i][1]].push_back(i+m); } state=0; find_cyc(cn[p][0]); state=1; find_cyc(cn[p][1]); for(cur=0;cur<n;cur++) { state=0; find_dist(cn[cur][0]); state=1; find_dist(cn[cur][0]); } for(i=0;i<Q;i++) { cnt=0; for(j=0;j<n;j++) { flag=0; for(k=0;k<2;k++) { if(d[k].dist[j]<0) continue; if(d[k].dist[j]==G[i])flag=1; if(d[k].dist[j]<G[i] && d[k].in_cyc && (G[i]-d[k].dist[j])%d[k].cyc_len==0)flag=1; } if(flag)cnt++; } answer(cnt); } }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...