結果
問題 |
No.2031 Colored Brackets
|
ユーザー |
|
提出日時 | 2022-08-03 23:23:35 |
言語 | PyPy3 (7.3.15) |
結果 |
WA
|
実行時間 | - |
コード長 | 802 bytes |
コンパイル時間 | 194 ms |
コンパイル使用メモリ | 82,064 KB |
実行使用メモリ | 848,252 KB |
最終ジャッジ日時 | 2024-09-15 16:27:32 |
合計ジャッジ時間 | 4,393 ms |
ジャッジサーバーID (参考情報) |
judge6 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 8 WA * 19 MLE * 1 -- * 2 |
ソースコード
import sys input = lambda: sys.stdin.readline().rstrip() ii = lambda: int(input()) mi = lambda: map(int, input().split()) li = lambda: list(mi()) inf = 2 ** 63 - 1 mod = 998244353 n = ii() s = input() if n >= 500: exit() dp = [[[0] * (2 * n) for _ in range(2 * n)] for _ in range(n + 1)] dp[1][1][0] = dp[1][0][1] = 1 dp[1][- 2][0] = dp[1][0][- 2] = -1 for i in range(1, n): for j in range(n): for k in range(n): if s[i] == '(': dp[i + 1][j][k] += dp[i][j % (2 * n)][(k - 1) % (2 * n)] + dp[i][(j - 1) % (2 * n)][k % (2 * n)] dp[i + 1][j][k] %= mod else: dp[i + 1][j][k] += dp[i][j % (2 * n)][(k + 1) % (2 * n)] + dp[i][(j + 1) % (2 * n)][k % (2 * n)] dp[i + 1][j][k] %= mod print(dp[n][0][0])