実行時間制限: 2 sec / メモリ制限: 1024 MB
配点 : 600 点
問題文
N 頂点 M 辺の単純無向グラフが与えられます。頂点には 1, \ldots, N の番号がついています。i 番目の辺は頂点 A_i と頂点 B_i を結んでいます。このグラフの全域部分グラフ(※)であって、次数が奇数の頂点がちょうど K 個であるものの個数をすべての K(0 \leq K \leq N) について求めてください。ただし答えは非常に大きくなる可能性があるので、998244353 で割った余りを出力してください。
(※)G の部分グラフ H が G の全域部分グラフであるとは、H の頂点集合が G の頂点集合と等しく、H の辺集合が G の辺集合の部分集合であることをいいます。
制約
- 1 \leq N \leq 5000
- 0 \leq M \leq 5000
- 1 \leq A_i , B_i \leq N
- 与えられるグラフは単純グラフである。すなわち、自己ループや多重辺は存在しない。
入力
入力は以下の形式で標準入力から与えられる。
N M A_1 B_1 A_2 B_2 : A_M B_M
出力
N+1 行出力せよ。i 行目には、K=i-1 のときの答えを出力せよ。
ans_0 ans_1 : ans_N
入力例 1
3 2 1 2 2 3
出力例 1
1 0 3 0
各全域部分グラフの次数が奇数の頂点の個数は以下の通りです。
- 辺が無いとき、次数が奇数の頂点は 0 個
- 1 と 2 を結ぶ辺だけがあるとき、次数が奇数の頂点は 2 個
- 2 と 3 を結ぶ辺だけがあるとき、次数が奇数の頂点は 2 個
- 両方の辺があるとき、次数が奇数の頂点は 2 個
入力例 2
4 2 1 2 3 4
出力例 2
1 0 2 0 1
Score : 600 points
Problem Statement
Given is a simple undirected graph with N vertices and M edges, where the vertices are numbered 1, \ldots, N and the i-th edge connects Vertex A_i and Vertex B_i. For each K(0 \leq K \leq N), find the number of spanning subgraphs (※) with exactly K vertices with odd degrees. Since the answers can be enormous, print it modulo 998244353.
(※) A subgraph H of G is said to be a spanning subgraph of G when the vertex set of H equals the vertex set of G and the edge set of H is a subset of the edge set of G.
Constraints
- 1 \leq N \leq 5000
- 0 \leq M \leq 5000
- 1 \leq A_i , B_i \leq N
- The given graph is simple, that is, it contains no self-loops and no multi-edges.
Input
Input is given from Standard Input in the following format:
N M A_1 B_1 A_2 B_2 : A_M B_M
Output
Print N+1 lines. The i-th line should contain the answer for K=i-1.
ans_0 ans_1 : ans_N
Sample Input 1
3 2 1 2 2 3
Sample Output 1
1 0 3 0
Each spanning subgraph has the following number of vertices with odd degrees:
- the subgraph with no edges has 0 vertices with odd degrees;
- the subgraph with just the edge connecting 1 and 2 has 2 vertices with odd degrees;
- the subgraph with just the edge connecting 2 and 3 has 2 vertices with odd degrees;
- the subgraph with both edges has 2 vertices with odd degrees.
Sample Input 2
4 2 1 2 3 4
Sample Output 2
1 0 2 0 1