結果
問題 | No.1433 Two color sequence |
ユーザー | nephrologist |
提出日時 | 2021-03-19 22:05:20 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 113 ms / 2,000 ms |
コード長 | 575 bytes |
コンパイル時間 | 515 ms |
コンパイル使用メモリ | 82,372 KB |
実行使用メモリ | 114,600 KB |
最終ジャッジ日時 | 2024-11-18 22:29:00 |
合計ジャッジ時間 | 3,772 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 21 |
ソースコード
n = int(input()) s = list(input()) A = list(map(int, input().split())) for i in range(n): if s[i] == "R": continue else: A[i] *= -1 cumA = [0] * (n + 1) for i in range(n): cumA[i + 1] = A[i] + cumA[i] plus = 0 minus = 0 pre_plus = 0 pre_minus = 0 for i in range(1, n + 1): score_plus = cumA[i] - cumA[pre_plus] score_minus = cumA[i] - cumA[pre_minus] if score_plus < 0: pre_plus = i if score_minus > 0: pre_minus = i plus = max(plus, score_plus) minus = min(minus, score_minus) print(max(plus, -minus))