結果
| 問題 |
No.2528 pop_(backfront or not)
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2023-11-12 18:47:54 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
AC
|
| 実行時間 | 889 ms / 2,000 ms |
| コード長 | 628 bytes |
| コンパイル時間 | 404 ms |
| コンパイル使用メモリ | 82,048 KB |
| 実行使用メモリ | 201,728 KB |
| 最終ジャッジ日時 | 2024-09-26 03:03:20 |
| 合計ジャッジ時間 | 6,983 ms |
|
ジャッジサーバーID (参考情報) |
judge2 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 19 |
ソースコード
n = int(input())
mod = 998244353
inv2 = pow(2, mod - 2, mod)
DP = [[0 for _ in range(2 * n + 1)] for _ in range(2 * n + 1)]
DP[0][0] = 1
for i in range(2 * n + 1):
for j in range(2 * n + 1):
if i >= 1 and j >= 1:
DP[i][j] += DP[i - 1][j - 1] * ((i - 1) * (j - 1) + 1) % mod
DP[i][j] %= mod
if i >= 2:
DP[i][j] += DP[i - 2][j] * (i - 1) * (i - 2) % mod * inv2 % mod
DP[i][j] %= mod
if j >= 2:
DP[i][j] += DP[i][j - 2] * (j - 1) * (j - 2) % mod * inv2 % mod
DP[i][j] %= mod
for i in range(2 * n + 1):
print(DP[i][2 * n - i])