203272026-01-06 14:12:50hunzombiBináris Sakkcpp17Hibás válasz 19/100423ms30412 KiB
#include <bits/stdc++.h>
using namespace std;

const long long MOD = 1e9 + 7;

int r, c, n;
vector<vector<int>> graph;
vector<bool> sz;

void dfs1(int node, vector<bool>& sz) {
    sz[node] = true;
    for (int next : graph[node]) {
        if (!sz[next]) {
            dfs1(next, sz);
        }
    }
}

vector<pair<int, int>> v1, v2, v3, v4;

int main()
{
    ios::sync_with_stdio(false);
    cin.tie(nullptr);

    cin >> r >> c >> n;
    sz.assign(n, false);
    graph.assign(n, vector<int>(0));
    for (int i=0; i < n; i++) {
        int u, v;
        cin >> u >> v;
        v1.push_back({u, i}); v2.push_back({v, i}); v3.push_back({abs(u - v), i}); v4.push_back({u + v, i});
    }

    sort(v1.begin(), v1.end());
    sort(v2.begin(), v2.end());
    sort(v3.begin(), v3.end());
    sort(v4.begin(), v4.end());

    for (int i=0; i < n - 1; i++) {
        if (v1[i].first == v1[i + 1].first) {
            graph[v1[i].second].push_back(v1[i + 1].second);
            graph[v1[i + 1].second].push_back(v1[i].second);
        }
        if (v2[i].first == v2[i + 1].first) {
            graph[v2[i].second].push_back(v2[i + 1].second);
            graph[v2[i + 1].second].push_back(v2[i].second);
        }
        if (v3[i].first == v3[i + 1].first) {
            graph[v3[i].second].push_back(v3[i + 1].second);
            graph[v3[i + 1].second].push_back(v3[i].second);
        }
        if (v4[i].first == v4[i + 1].first) {
            graph[v4[i].second].push_back(v4[i + 1].second);
            graph[v4[i + 1].second].push_back(v4[i].second);
        }
    }

    long long ans = 0;
    for (int i=0; i < n; i++) {
        if (!sz[i]) {
            dfs1(i, sz);
            ans++;
        }
    }

    long long res = 1;

    while (ans > 0) {
        res = (res * 2) % MOD;
        ans--;
    }

    cout << res << '\n';

    return 0;
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
subtask10/0
1Elfogadva1ms508 KiB
2Elfogadva1ms316 KiB
subtask20/11
3Elfogadva2ms316 KiB
4Elfogadva1ms316 KiB
5Elfogadva1ms316 KiB
6Elfogadva1ms316 KiB
7Elfogadva1ms316 KiB
8Hibás válasz1ms316 KiB
9Hibás válasz1ms316 KiB
10Elfogadva2ms316 KiB
11Hibás válasz2ms388 KiB
12Hibás válasz2ms500 KiB
13Hibás válasz2ms316 KiB
14Elfogadva1ms508 KiB
15Elfogadva1ms316 KiB
16Elfogadva1ms564 KiB
17Elfogadva2ms316 KiB
18Hibás válasz1ms508 KiB
subtask30/19
19Elfogadva115ms12856 KiB
20Elfogadva26ms3252 KiB
21Elfogadva24ms3108 KiB
22Elfogadva307ms29364 KiB
23Elfogadva43ms5188 KiB
24Elfogadva13ms1844 KiB
25Elfogadva418ms30412 KiB
26Elfogadva423ms30408 KiB
27Elfogadva331ms30328 KiB
28Elfogadva351ms30328 KiB
29Elfogadva273ms29056 KiB
30Elfogadva247ms29564 KiB
31Hibás válasz395ms30268 KiB
32Hibás válasz356ms30328 KiB
subtask419/19
33Elfogadva2ms508 KiB
34Elfogadva2ms316 KiB
35Elfogadva1ms316 KiB
36Elfogadva1ms316 KiB
37Elfogadva1ms316 KiB
38Elfogadva1ms316 KiB
39Elfogadva2ms316 KiB
40Elfogadva1ms316 KiB
41Elfogadva2ms500 KiB
42Elfogadva2ms332 KiB
43Elfogadva1ms564 KiB
44Elfogadva1ms316 KiB
45Elfogadva2ms780 KiB
46Elfogadva2ms564 KiB
47Elfogadva2ms316 KiB
subtask50/51
48Elfogadva13ms1456 KiB
49Elfogadva32ms2692 KiB
50Elfogadva119ms9028 KiB
51Hibás válasz143ms9604 KiB
52Hibás válasz54ms3996 KiB
53Hibás válasz75ms5428 KiB
54Hibás válasz30ms2732 KiB
55Elfogadva12ms1332 KiB
56Elfogadva32ms2732 KiB
57Hibás válasz171ms11200 KiB
58Hibás válasz172ms11384 KiB
59Hibás válasz172ms11476 KiB
60Hibás válasz172ms11384 KiB
61Hibás válasz174ms11464 KiB
62Hibás válasz172ms11384 KiB
63Elfogadva125ms27000 KiB
64Elfogadva120ms27044 KiB
65Elfogadva134ms27004 KiB
66Elfogadva130ms27004 KiB
67Hibás válasz173ms11384 KiB
68Hibás válasz170ms11340 KiB