結果
問題 | No.1802 Range Score Query for Bracket Sequence |
ユーザー |
|
提出日時 | 2022-01-14 17:59:20 |
言語 | PyPy3 (7.3.15) |
結果 |
RE
|
実行時間 | - |
コード長 | 823 bytes |
コンパイル時間 | 355 ms |
コンパイル使用メモリ | 82,396 KB |
実行使用メモリ | 87,456 KB |
最終ジャッジ日時 | 2024-11-19 12:27:34 |
合計ジャッジ時間 | 4,603 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 1 |
other | AC * 2 RE * 22 |
ソースコード
N,Q = map(int,input().split()) S = input() bit = [0] * N def add(i,x): while i <= N: bit[i] += x i += i & -i def getsum(i): ans = 0 while i > 0: ans += bit[i] i -= i & -i return ans l = list(S) for i in range(N-1): if l[i] == '(' and l[i+1] == ')': add(i+1,1) for _ in range(Q): t = list(map(int,input().split())) if t[0] == 2: print(getsum(t[2]-1)-getsum(t[1]-1)) else: i = t[1] if l[i-1] == '(': if i < N and l[i] == ')': add(i,-1) if i >= 2 and l[i-2] == '(': add(i-1,1) l[i-1] = ')' else: if i >= 2 and l[i-2] == '(': add(i-1,-1) if i < N and l[i] == ')': add(i,1) l[i-1] == ')'