結果
問題 |
No.2733 Just K-times TSP
|
ユーザー |
|
提出日時 | 2024-03-23 20:19:13 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 803 ms / 2,000 ms |
コード長 | 638 bytes |
コンパイル時間 | 661 ms |
コンパイル使用メモリ | 82,176 KB |
実行使用メモリ | 141,312 KB |
最終ジャッジ日時 | 2024-10-11 13:07:53 |
合計ジャッジ時間 | 6,166 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 32 |
ソースコード
from collections import defaultdict mod = 998244353 N, M, K = map(int, input().split()) pows = [(K + 1) ** i for i in range(N + 1)] g = [[] for _ in range(N)] for _ in range(M): u, v = map(int, input().split()) u -= 1 v -= 1 g[u].append(v) g[v].append(u) dp = [[0] * N for _ in range(pows[N])] for i in range(N): dp[pows[i]][i] = 1 for i in range(pows[N]): for u in range(N): x = (i // pows[u]) % (K + 1) if 0 < x: for v in g[u]: y = (i // pows[v]) % (K + 1) if y < K: dp[i + pows[v]][v] += dp[i][u] dp[i + pows[v]][v] %= mod ans = 0 for i in range(N): ans += dp[pows[N] - 1][i] ans %= mod print(ans)