結果
問題 |
No.2031 Colored Brackets
|
ユーザー |
|
提出日時 | 2022-08-07 17:12:29 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 106 ms / 2,000 ms |
コード長 | 588 bytes |
コンパイル時間 | 506 ms |
コンパイル使用メモリ | 82,848 KB |
実行使用メモリ | 76,336 KB |
最終ジャッジ日時 | 2024-09-17 10:15:19 |
合計ジャッジ時間 | 3,733 ms |
ジャッジサーバーID (参考情報) |
judge6 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 30 |
ソースコード
N = int(input()) S = input() P = 998244353 C = (N // 2) + 1 dp = [0] * C dp[0] = 1 now = 0 for s in S: nx = [0] * C for red in range(C): blue = now - red if blue < 0:continue if s == "(": if red < C - 1: nx[red + 1] += dp[red] nx[red] += dp[red] else: if red > 0: nx[red - 1] += dp[red] if blue > 0: nx[red] += dp[red] for red in range(C): nx[red] %= P dp = nx if s == "(": now += 1 else: now -= 1 print(dp[0])