# | Submission time | Handle | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
1035170 | 2024-07-26T05:29:44 Z | vjudge1 | Pipes (CEOI15_pipes) | C++ | 806 ms | 65536 KB |
#include <iostream> #include <vector> using namespace std; const int N = 1e5+2; namespace d1 { int e[N]; int find(int &x) { return e[x] < 0 ? x : e[x] = find(e[x]); } bool join(int a, int b) { a = find(a), b = find(b); if (a == b) return false; if (e[a] > e[b]) swap(a, b); e[a] += e[b]; e[b] = a; return true; } }; namespace d2 { int e[N]; int find(int &x) { return e[x] < 0 ? x : e[x] = find(e[x]); } bool join(int a, int b) { a = find(a), b = find(b); if (a == b) return false; if (e[a] > e[b]) swap(a, b); e[a] += e[b]; e[b] = a; return true; } }; vector<int> g[N]; int timer=0; void dfs(int at, int par) { d1::e[at]=d2::e[at]=++timer; for(int to:g[at]) { if(to == par) { par+=N; continue; } if(d2::e[to]) { d1::e[at]=min(d1::e[at], d2::e[to]); } else { dfs(to, at); d1::e[at]=min(d1::e[at], d1::e[to]); } } if(par>N)par-=N; if(d1::e[at] == d2::e[at] and at!=par) { printf("%d %d\n", at, par); } } int n, m, u, v; int main() { srand(time(0)); scanf("%d %d", &n, &m); //nt u, v; for(int i = 1;i<N;i++)d1::e[i]=d2::e[i]=-1; for(int i = 0;i<m;i++) { scanf("%d %d", &u, &v); if((d1::join(u, v) || d2::join(u, v))) { g[u].push_back(v); g[v].push_back(u); } } for(int i = 1;i<N;i++)d1::e[i]=d2::e[i]=0; for(int i= 1;i<=n;i++) { if(!d1::e[i]) { dfs(i, i); } } }
Compilation message
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
1 | Correct | 2 ms | 3420 KB | Output is correct |
2 | Correct | 2 ms | 3560 KB | Output is correct |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
1 | Correct | 4 ms | 4184 KB | Output is correct |
2 | Correct | 4 ms | 3676 KB | Output is correct |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
1 | Correct | 68 ms | 9040 KB | Output is correct |
2 | Correct | 66 ms | 8784 KB | Output is correct |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
1 | Correct | 112 ms | 13136 KB | Output is correct |
2 | Correct | 150 ms | 14672 KB | Output is correct |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
1 | Runtime error | 196 ms | 20580 KB | Memory limit exceeded |
2 | Halted | 0 ms | 0 KB | - |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
1 | Runtime error | 264 ms | 28432 KB | Memory limit exceeded |
2 | Halted | 0 ms | 0 KB | - |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
1 | Runtime error | 398 ms | 40276 KB | Memory limit exceeded |
2 | Halted | 0 ms | 0 KB | - |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
1 | Runtime error | 519 ms | 51464 KB | Memory limit exceeded |
2 | Halted | 0 ms | 0 KB | - |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
1 | Runtime error | 639 ms | 61708 KB | Memory limit exceeded |
2 | Halted | 0 ms | 0 KB | - |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
1 | Runtime error | 806 ms | 65536 KB | Memory limit exceeded |
2 | Halted | 0 ms | 0 KB | - |