結果
問題 |
No.2031 Colored Brackets
|
ユーザー |
|
提出日時 | 2022-08-03 23:32:48 |
言語 | PyPy3 (7.3.15) |
結果 |
RE
|
実行時間 | - |
コード長 | 823 bytes |
コンパイル時間 | 956 ms |
コンパイル使用メモリ | 82,148 KB |
実行使用メモリ | 848,532 KB |
最終ジャッジ日時 | 2024-09-15 16:28:06 |
合計ジャッジ時間 | 4,466 ms |
ジャッジサーバーID (参考情報) |
judge6 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 8 RE * 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 >= 300: raise Exception 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 * n - 2][0] = dp[1][0][2 * n - 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])