답안 #56329

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
56329 2018-07-11T05:14:08 Z admin Pipes (CEOI15_pipes) C++14
100 / 100
1436 ms 7940 KB
#include <bits/stdc++.h>
using namespace std;
 
const int N = 100001, H = 17;
 
int n, m, p[N], P[N], c[N], d[N], s[N];
vector<int> e[N];
 
int f(int x){ return p[x] = (x == p[x] ? x : f(p[x])); }
int F(int x){ return P[x] = (x == P[x] ? x : F(P[x])); }
 
void g(int x, int y, int z){
    for(int i : e[x]) if(i != y) g(i, x, z + 1);
    if(s[x] != y && x != f(x)) P[s[x]] = (P[x] == x ? s[x] : x);
    d[x] = z; s[x] = y;
}
 
int main(){
    scanf("%d%d", &n, &m);
    iota(p, p + n + 1, 0);
    iota(P, P + n + 1, 0);
    iota(s, s + n + 1, 0);
    fill(c + 1, c + n + 1, 1);
    for(int x, y; m--; ){
        scanf("%d%d", &x, &y);
        if(f(x) != f(y)){
            if(c[f(x)] < c[f(y)]) swap(x, y);
            g(y, x, d[x] + 1); P[y] = y;
            e[x].push_back(y); e[y].push_back(x);
            c[f(x)] += c[f(y)]; p[f(y)] = f(x);
        }
        else{
            x = F(x); y = F(y);
            while(x != y){
                if(d[x] > d[y]){ P[x] = F(P[s[x]]); x = F(x); }
                else{ P[y] = F(P[s[y]]); y = F(y); }
            }
        }
    }
    for(int i = 1; i <= n; i++) if(P[i] == i && s[i] != i) printf("%d %d\n", i, s[i]);
}

Compilation message

pipes.cpp: In function 'int main()':
pipes.cpp:19:10: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
     scanf("%d%d", &n, &m);
     ~~~~~^~~~~~~~~~~~~~~~
pipes.cpp:25:14: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
         scanf("%d%d", &x, &y);
         ~~~~~^~~~~~~~~~~~~~~~
# 결과 실행 시간 메모리 Grader output
1 Correct 3 ms 2688 KB Output is correct
2 Correct 3 ms 2688 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 7 ms 2944 KB Output is correct
2 Correct 7 ms 2944 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 112 ms 2816 KB Output is correct
2 Correct 111 ms 2816 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 195 ms 3200 KB Output is correct
2 Correct 231 ms 3200 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 322 ms 3840 KB Output is correct
2 Correct 286 ms 4216 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 440 ms 6288 KB Output is correct
2 Correct 401 ms 6264 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 697 ms 6812 KB Output is correct
2 Correct 709 ms 6848 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 945 ms 7704 KB Output is correct
2 Correct 928 ms 7816 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 1207 ms 7708 KB Output is correct
2 Correct 1161 ms 7940 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 1436 ms 7476 KB Output is correct
2 Correct 1413 ms 7796 KB Output is correct