222782026-01-14 19:49:41algoproTrükkcpp17Wrong answer 0/6037ms1552 KiB
// UUID: 16bbe0bd-4476-4211-a713-f9898229c930
#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].push_back(b);
        adj[b].push_back(a);
    }

    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
base0/60
1Accepted0/01ms508 KiB
2Wrong answer0/018ms1024 KiB
3Wrong answer0/31ms500 KiB
4Wrong answer0/31ms316 KiB
5Wrong answer0/31ms316 KiB
6Wrong answer0/31ms316 KiB
7Wrong answer0/237ms1360 KiB
8Wrong answer0/237ms1456 KiB
9Wrong answer0/237ms1392 KiB
10Wrong answer0/237ms1484 KiB
11Wrong answer0/237ms1360 KiB
12Wrong answer0/237ms1400 KiB
13Wrong answer0/228ms1252 KiB
14Wrong answer0/228ms1100 KiB
15Wrong answer0/228ms1248 KiB
16Wrong answer0/228ms1360 KiB
17Wrong answer0/228ms1360 KiB
18Wrong answer0/228ms1372 KiB
19Wrong answer0/237ms1540 KiB
20Wrong answer0/237ms1356 KiB
21Wrong answer0/237ms1360 KiB
22Wrong answer0/235ms1400 KiB
23Wrong answer0/237ms1360 KiB
24Wrong answer0/237ms1360 KiB
25Wrong answer0/237ms1360 KiB
26Wrong answer0/228ms1552 KiB
27Wrong answer0/237ms1360 KiB
28Wrong answer0/234ms1484 KiB
29Wrong answer0/214ms1104 KiB
30Wrong answer0/214ms1104 KiB