답안 #46455

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
46455 2018-04-20T22:10:19 Z alex99 Pipes (CEOI15_pipes) C++14
100 / 100
1468 ms 7896 KB
#include <iostream>
#include <vector>
#include <cstdlib>
#include <cstdio>
#include <ctime>
using namespace std;
int N, M;
int TT[100005], R[100005];
long long Sum[100005];
int F[100005];
vector <int> G[100005];
bool Use[100005];
void Unite(int x, int y)
{
    if(x == y)
        return;
    if(R[x] < R[y])
    {
        TT[x] = y;
    }
    else
        TT[y] = x;
    if(R[x] == R[y])
        R[x]++;
}

int Father(int x)
{
    int init = x;
    while(x != TT[x])
        x = TT[x];
    while(init != x)
    {
        int next = TT[init];
        TT[init] = x;
        init = next;
    }
    return x;
}

void DFS(int node)
{
    Use[node] = 1;
    for(int i = 0; i < G[node].size(); i++)
    {
        int neighb = G[node][i];
        if(neighb == F[node])
            continue;
        F[neighb] = node;
        DFS(neighb);
        Sum[node] += Sum[neighb];
    }
    if(Sum[node] == 0 && F[node] != 0)
    {
        printf("%d %d\n", node, F[node]);
    }
}

void Solve()
{
    scanf("%d%d", &N, &M);
    for(int i = 1; i <= N; i++)
        TT[i] = i;
    for(int i = 1; i <= M; i++)
    {
        int x, y;
        scanf("%d%d", &x, &y);
        if(Father(x) == Father(y))
        {
            int r = rand();
            Sum[x] += r;
            Sum[y] -= r;
        }
        else
        {
            G[x].push_back(y);
            G[y].push_back(x);
            Unite(Father(x), Father(y));
        }
    }
    for(int i = 1; i <= N; i++)
        if(Use[i] == 0)
            DFS(i);
}
int main()
{
    srand(time(NULL));
    Solve();
    return 0;
}

Compilation message

pipes.cpp: In function 'void DFS(int)':
pipes.cpp:44:22: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
     for(int i = 0; i < G[node].size(); i++)
                    ~~^~~~~~~~~~~~~~~~
pipes.cpp: In function 'void Solve()':
pipes.cpp:61: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:67: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 120 ms 2816 KB Output is correct
2 Correct 115 ms 2936 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 210 ms 3200 KB Output is correct
2 Correct 239 ms 3192 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 338 ms 3844 KB Output is correct
2 Correct 289 ms 4216 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 483 ms 6272 KB Output is correct
2 Correct 420 ms 6264 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 883 ms 6912 KB Output is correct
2 Correct 739 ms 6920 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 1010 ms 7780 KB Output is correct
2 Correct 912 ms 7800 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 1190 ms 7780 KB Output is correct
2 Correct 1145 ms 7800 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 1468 ms 7652 KB Output is correct
2 Correct 1458 ms 7896 KB Output is correct