Submission #993649


Source Code Expand

#include <iostream>
#include <vector>
using namespace std;

struct UnionFind {
    vector<int> data;
    UnionFind(int size) : data(size, -1) { }
    bool unionSet(int x, int y) {
        x = root(x); y = root(y);
        if (x != y) {
            if (data[y] < data[x]) swap(x, y);
            data[x] += data[y]; data[y] = x;
        }
        return x != y;
    }
    bool findSet(int x, int y) {
        return root(x) == root(y);
    }
    int root(int x) {
        return data[x] < 0 ? x : data[x] = root(data[x]);
    }
    int size(int x) {
        return -data[root(x)];
    }
};

int main(void)
{
    int N, M;
    cin >> N >> M;

    int K, L;
    vector<int> *lang = new vector<int>[M];
    UnionFind u(N);

    for (int i = 0; i < N; i++) {
        cin >> K;

        for (int j = 0; j < K; j++) {
            cin >> L;
            lang[L - 1].push_back(i);

            u.unionSet(lang[L - 1][0], i);
        }
    }

    delete[] lang;

    for (int i = 1; i < N; i++) {
        if (!u.findSet(0, i)) {
            cout << "NO" << endl;
            return 0;
        }
    }

    cout << "YES" << endl;
    return 0;
}

Submission Info

Submission Time
Task C - Interpretation
User hiromu
Language C++14 (GCC 5.4.1)
Score 400
Code Size 1190 Byte
Status AC
Exec Time 53 ms
Memory 4608 KB

Judge Result

Set Name sample dataset1 dataset2
Score / Max Score 0 / 0 200 / 200 200 / 200
Status
AC × 2
AC × 12
AC × 25
Set Name Test Cases
sample sample-01.txt, sample-02.txt
dataset1 sample-01.txt, sample-02.txt, 01-01.txt, 01-02.txt, 01-03.txt, 01-04.txt, 01-05.txt, 01-06.txt, 01-07.txt, 01-08.txt, 01-09.txt, 01-10.txt
dataset2 sample-01.txt, sample-02.txt, 01-01.txt, 01-02.txt, 01-03.txt, 01-04.txt, 01-05.txt, 01-06.txt, 01-07.txt, 01-08.txt, 01-09.txt, 01-10.txt, 02-01.txt, 02-02.txt, 02-03.txt, 02-04.txt, 02-05.txt, 02-06.txt, 02-07.txt, 02-08.txt, 02-09.txt, 02-10.txt, 02-11.txt, 02-12.txt, 02-13.txt
Case Name Status Exec Time Memory
01-01.txt AC 3 ms 256 KB
01-02.txt AC 3 ms 256 KB
01-03.txt AC 3 ms 256 KB
01-04.txt AC 3 ms 256 KB
01-05.txt AC 3 ms 256 KB
01-06.txt AC 3 ms 256 KB
01-07.txt AC 3 ms 256 KB
01-08.txt AC 3 ms 256 KB
01-09.txt AC 3 ms 256 KB
01-10.txt AC 3 ms 256 KB
02-01.txt AC 44 ms 4608 KB
02-02.txt AC 42 ms 1152 KB
02-03.txt AC 43 ms 2816 KB
02-04.txt AC 53 ms 4224 KB
02-05.txt AC 47 ms 1536 KB
02-06.txt AC 52 ms 4224 KB
02-07.txt AC 49 ms 1664 KB
02-08.txt AC 34 ms 1152 KB
02-09.txt AC 51 ms 3580 KB
02-10.txt AC 44 ms 3456 KB
02-11.txt AC 45 ms 3456 KB
02-12.txt AC 44 ms 3328 KB
02-13.txt AC 44 ms 3328 KB
sample-01.txt AC 3 ms 256 KB
sample-02.txt AC 3 ms 256 KB