# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
154232 | arnold518 | Pipes (CEOI15_pipes) | C++14 | 1781 ms | 13756 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef pair<int, int> pii;
typedef pair<ll, ll> pll;
const int MAXN = 1e5;
struct UF
{
int par[MAXN+1];
UF() { for(int i=0; i<=MAXN; i++) par[i]=i; }
int Find(int x)
{
if(x==par[x]) return x;
return par[x]=Find(par[x]);
}
void Union(int x, int y)
{
x=Find(x); y=Find(y);
par[x]=y;
}
};
UF uf1, uf2;
int N, M;
vector<int> adj[MAXN+1];
int idx[MAXN+1], cnt=1;
int dfs(int now, int bef)
{
idx[now]=cnt++;
int ret=idx[now];
int k=0;
for(int nxt : adj[now])
{
if(nxt==bef) { k++; continue; }
if(idx[nxt]!=0) ret=min(ret, idx[nxt]);
else
{
int t=dfs(nxt, now);
ret=min(ret, t);
if(t>idx[now]) printf("%d %d\n", now, nxt);
}
}
if(k>1) ret=min(ret, idx[bef]);
return ret;
}
int main()
{
int i, j;
scanf("%d%d", &N, &M);
while(M--)
{
int u, v;
scanf("%d%d", &u, &v);
if(uf1.Find(u)!=uf1.Find(v)) uf1.Union(u, v), adj[u].push_back(v), adj[v].push_back(u);
else if(uf2.Find(u)!=uf2.Find(v)) uf2.Union(u, v), adj[u].push_back(v), adj[v].push_back(u);
}
for(i=1; i<=N; i++) if(idx[i]==0) dfs(i, i);
}
컴파일 시 표준 에러 (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... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |