結果
| 問題 | No.2277 Honest or Dishonest ? | 
| コンテスト | |
| ユーザー |  rlangevin | 
| 提出日時 | 2023-04-21 21:48:57 | 
| 言語 | PyPy3 (7.3.15) | 
| 結果 | 
                                AC
                                 
                             | 
| 実行時間 | 268 ms / 2,000 ms | 
| コード長 | 743 bytes | 
| コンパイル時間 | 614 ms | 
| コンパイル使用メモリ | 82,304 KB | 
| 実行使用メモリ | 92,032 KB | 
| 最終ジャッジ日時 | 2024-11-08 06:29:43 | 
| 合計ジャッジ時間 | 11,098 ms | 
| ジャッジサーバーID (参考情報) | judge1 / judge4 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| sample | AC * 3 | 
| other | AC * 50 | 
ソースコード
import sys
readline = sys.stdin.readline
from collections import *
N, Q = map(int, readline().split())
G = [[] for i in range(N)]
ans = 1
mod = 998244353
for i in range(Q):
    A, B, C = map(int, readline().split())
    A, B = A - 1, B - 1
    G[A].append((B, C))
    G[B].append((A, C))
    
D = deque()
dist = [-1] * N
for i in range(N):
    if dist[i] != -1:
        continue
    ans *= 2
    ans %= mod
    D.append(i)
    dist[i] = 0
    while D:
        u = D.popleft()
        for v, c in G[u]:
            if dist[v] == -1:
                dist[v] = (dist[u] + c) % 2
                D.append(v)
            else:
                if dist[v] != (dist[u] + c) % 2:
                    print(0)
                    exit()
print(ans)
    
            
            
            
        