222832026-01-14 19:56:14algoproTrükkcpp17Accepted 60/6043ms1956 KiB
// UUID: 45ce29fe-04ad-4eb7-bc35-b9190ab01650
#include <bits/stdc++.h>
using namespace std;
const int MOD = 1e9 + 7;

int e(int n){
    int a = 1;
    for (int i = 0; i < n; i++) {
        a = a*2 % MOD;
    }
    return a;
}

bool isbiparte(int node, const vector<vector<int>>& adj, vector<int>& visited){
    bool f = true;
    for (int i : adj[node]) {
        if (visited[i] != 0) {
            if (visited[i] == visited[node]) return false;
            continue;
        }
        visited[i] = visited[node] % 2 + 1;
        f = (f && isbiparte(i, adj, visited));
    }
    return f;
}

void solve() {
    int n, m;
    cin >> n >> m;

    vector<vector<int>> adj(n+1);

    for (int i = 0; i < m; i++) {
        int a, b;
        cin >> a >> b;
        adj[a-1].push_back(b);
        adj[b].push_back(a-1);
    }

    int res = 0;
    vector<int> visited(n + 1, 0);

    for (int i = 0; i <= n; i++) {
        if (visited[i] != 0) continue;
        visited[i] = 1;
        if (!isbiparte(i, adj, visited)){
            cout << "0\n";
            return;
        } else res++;
    }
    cout << e(res-1) << "\n";
    return;
}

int main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr);
    int t = 1;
    cin >> t;
    while (t--) {
        solve();
    }
    return 0;
}
SubtaskSumTestVerdictTimeMemory
base60/60
1Accepted0/01ms508 KiB
2Accepted0/021ms1056 KiB
3Accepted3/31ms316 KiB
4Accepted3/31ms508 KiB
5Accepted3/31ms508 KiB
6Accepted3/31ms316 KiB
7Accepted2/241ms1736 KiB
8Accepted2/237ms1644 KiB
9Accepted2/239ms1560 KiB
10Accepted2/241ms1696 KiB
11Accepted2/239ms1620 KiB
12Accepted2/237ms1624 KiB
13Accepted2/228ms1332 KiB
14Accepted2/228ms1220 KiB
15Accepted2/228ms1332 KiB
16Accepted2/230ms1356 KiB
17Accepted2/229ms1376 KiB
18Accepted2/229ms1360 KiB
19Accepted2/243ms1784 KiB
20Accepted2/241ms1956 KiB
21Accepted2/241ms1844 KiB
22Accepted2/237ms1712 KiB
23Accepted2/237ms1612 KiB
24Accepted2/237ms1616 KiB
25Accepted2/237ms1692 KiB
26Accepted2/228ms1360 KiB
27Accepted2/239ms1608 KiB
28Accepted2/234ms1360 KiB
29Accepted2/214ms1104 KiB
30Accepted2/214ms1156 KiB