Submission #154848

#TimeUsernameProblemLanguageResultExecution timeMemory
154848TadijaSebezPipes (CEOI15_pipes)C++11
50 / 100
1711 ms54524 KiB
#include <bits/stdc++.h> using namespace std; const int N=100050; const int M=4*N; struct DSU { int p[N]; DSU(){} int Find(int x){ return !p[x]?x:p[x]=Find(p[x]);} void Union(int x, int y){ p[Find(x)]=Find(y);} bool Same(int x, int y){ return Find(x)==Find(y);} } D1,D2; int go[M],fir[N],tsz=1,f[M]; void Add(int x, int y){ tsz++;go[tsz]=fir[x];f[tsz]=y;fir[x]=tsz;} void AddEdge(int x, int y){ Add(x,y);Add(y,x);} int disc[N],low[N],tid; void DFS(int u, int p) { disc[u]=low[u]=++tid; for(int i=fir[u];i;i=go[i]) if(i/2!=p) { int v=f[i]; if(!disc[v]) { DFS(v,i/2); if(low[v]>disc[u]) printf("%i %i\n",u,v); low[u]=min(low[u],low[v]); } else low[u]=min(low[u],disc[v]); } } int main() { int n,m,u,v; scanf("%i %i",&n,&m); for(int i=1;i<=m;i++) { scanf("%i %i",&u,&v); if(!D1.Same(u,v)) { D1.Union(u,v); AddEdge(u,v); } else if(!D2.Same(u,v)) { D2.Union(u,v); AddEdge(u,v); } } for(int i=1;i<=n;i++) if(!disc[i]) DFS(i,-1); return 0; }

Compilation message (stderr)

pipes.cpp: In function 'int main()':
pipes.cpp:35:7: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
  scanf("%i %i",&n,&m);
  ~~~~~^~~~~~~~~~~~~~~
pipes.cpp:38:8: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   scanf("%i %i",&u,&v);
   ~~~~~^~~~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...