222732026-01-14 19:44:38algoproTrükkcpp17Wrong answer 0/6043ms1624 KiB
// UUID: a5740b89-b3d0-4715-877f-fa3980781067
#include <bits/stdc++.h>
using namespace std;
const int MOD = 1e9 + 7;

int e(int n){
    if (n == 0) return 1;
    else return (2*e(n-1)) % MOD;
}

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 true;
}

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 = 1; 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) << "\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/01ms500 KiB
2Wrong answer0/019ms1028 KiB
3Wrong answer0/31ms316 KiB
4Wrong answer0/31ms500 KiB
5Wrong answer0/31ms316 KiB
6Wrong answer0/31ms316 KiB
7Wrong answer0/239ms1336 KiB
8Wrong answer0/241ms1616 KiB
9Wrong answer0/239ms1616 KiB
10Wrong answer0/239ms1460 KiB
11Wrong answer0/239ms1360 KiB
12Wrong answer0/239ms1572 KiB
13Wrong answer0/227ms1244 KiB
14Wrong answer0/227ms1104 KiB
15Wrong answer0/228ms1104 KiB
16Wrong answer0/228ms1364 KiB
17Wrong answer0/228ms1548 KiB
18Wrong answer0/228ms1360 KiB
19Wrong answer0/241ms1624 KiB
20Wrong answer0/243ms1616 KiB
21Wrong answer0/241ms1552 KiB
22Wrong answer0/237ms1360 KiB
23Wrong answer0/239ms1484 KiB
24Wrong answer0/239ms1360 KiB
25Wrong answer0/237ms1332 KiB
26Wrong answer0/227ms1268 KiB
27Wrong answer0/241ms1456 KiB
28Wrong answer0/234ms1428 KiB
29Wrong answer0/214ms1076 KiB
30Wrong answer0/214ms1076 KiB