#include using namespace std; template struct BIT{ vector num; int N; BIT(int n) : N(n + 1){ num.resize(N, 0); } /* 区間 [l, r)(0-indexed)のsumを知りたいとき sum(r) - sum(l); */ T sum(T t){ long long res = 0; assert(t < N); while(t > 0){ res += num.at(t); t -= t & -t; } return res; } void add(int ind, T t){ ind++; assert(ind < N); while(ind < N){ num[ind] += t; ind += ind & -ind; } } T query(int l, int r){ assert(r < N && l < N); return sum(r) - sum(l - 1); } int lower_bound(T k){//累積和がk以上となる最小のindexを返す int ind = 0; int beki = 1; assert(k >= 0); while(beki < N) beki <<= 1; for(int i = beki; i > 0; i >>= 1){ if(ind + i < N && num[ind + i] < k){ k -= num[ind + i]; ind += i; } } return ind; } }; int main(){ int N, Q; cin >> N >> Q; string S; cin >> S; BIT bit(N); for(int i = 0; i < N - 1; i++){ if(S[i] == '(' && S[i + 1] == ')') bit.add(i, 1); } while(Q--){ int t; cin >> t; if(t == 1){ int s; cin >> s; s--; if(S[s] == '(') { S[s] = ')'; if(s < N - 1 && S[s + 1] == ')') bit.add(s, -1); if(s > 0 && S[s - 1] == '(') bit.add(s - 1, 1); } else { S[s] = '('; if(s > 0 && S[s - 1] == '(') bit.add(s - 1, -1); if(s < N - 1 && S[s + 1] == ')') bit.add(s, 1); } } else{ int l, r; cin >> l >> r; int temp = bit.query(l, r); if(bit.query(r, r) == 1) temp--; cout << temp << endl; } } }