結果
| 問題 |
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])