結果
問題 |
No.1802 Range Score Query for Bracket Sequence
|
ユーザー |
|
提出日時 | 2022-01-14 18:15:51 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 633 ms / 2,000 ms |
コード長 | 824 bytes |
コンパイル時間 | 154 ms |
コンパイル使用メモリ | 82,560 KB |
実行使用メモリ | 88,028 KB |
最終ジャッジ日時 | 2024-06-30 02:22:19 |
合計ジャッジ時間 | 9,993 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 1 |
other | AC * 24 |
ソースコード
N,Q = map(int,input().split()) S = input() bit = [0] * N def add(i,x): while i <= N-1: 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] = '('