티스토리 뷰

Algorithm

[백준 18267] Milk Visits

devbelly 2020. 11. 17. 15:20

문제

www.acmicpc.net/problem/18267

 

알고리즘

union find

 

풀이

트리에서 각 노드마다 소의 종류가 정해져 있을 때, 주어진 쿼리에서 그 사이 경로에 해당 소가 있는지 찾는 문제입니다.

 

트리에서 인접한 노드가 서로 같은 종류의 소라면 유니온 파인드를 통해 묶어줍시다. 이후 쿼리에서 두 노드의 부모노드가 다르다면 경로상에 두 종류의 소가 있음을 알 수 있습니다. 만약 부모노드가 같다면 그 부모노드의 소가 어떤 종류인지 찾아 비교해주면 됩니다.

 

코드

#include <bits/stdc++.h>
#define rep(i, n) for (int i = 0; i < n; ++i)
#define REP(i, n) for (int i = 1; i <= n; ++i)
using namespace std;

const int MAXN = 1e5;

int N, M;
int p[MAXN];
char w[MAXN];

int find(int x) {
    return p[x] < 0 ? x : (p[x] = find(p[x]));
}

int main() {
#ifndef ONLINE_JUDGE
    freopen("in", "r", stdin);
    freopen("out", "w", stdout);
#endif
    cin.tie(NULL);
    cout.tie(NULL);
    ios::sync_with_stdio(false);

    cin >> N >> M;
    memset(p, -1, sizeof(p));
    rep(i, N) {
        cin >> w[i];
    }
    rep(i, N - 1) {
        int u, v;
        cin >> u >> v;
        --u, --v;
        int pu = find(u);
        int pv = find(v);
        if (w[pu] ^ w[pv])
            continue;
        p[pu] = pv;
    }

    while (M--) {
        int u, v;
        char x;
        cin >> u >> v >> x;
        --u, --v;
        int pu = find(u);
        int pv = find(v);
        if (pu ^ pv)
            cout << 1;
        else if (w[pu] == x)
            cout << 1;
        else
            cout << 0;
    }

    return 0;
}

'Algorithm' 카테고리의 다른 글

[백준 16768] Mooyo Mooyo  (0) 2020.11.22
[백준 16767] Convention II  (0) 2020.11.21
[백준 13510] 트리와 쿼리1  (0) 2020.11.16
[백준 18784] Triangles (Silver)  (0) 2020.11.15
[백준 1626] 두 번째로 작은 스패닝 트리  (0) 2020.11.14
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2024/11   »
1 2
3 4 5 6 7 8 9
10 11 12 13 14 15 16
17 18 19 20 21 22 23
24 25 26 27 28 29 30
글 보관함