#include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include using namespace std; using namespace atcoder; int op(int a, int b) { return a + b; } int e() { return 0; } bool bo(int x){ if (x == 0) { return true; } else { return false; } } int main() { int n, q; cin >> n >> q; segtree seg(n + 10), seg1(n + 10); string s; cin >> s; s = '.' + s; for (int i = 1; i <= n; i++) { if (s[i] != s[i - 1]) { if (s[i] == '(') { seg.set(i, 1); } else { seg1.set(i, 1); } } } for (int i = 0; i < q; i++) { int que; cin >> que; if (que == 1) { int i; cin >> i; if (s[i] == s[i - 1]) { if (s[i] == '(') { seg1.set(i, 1); } else { seg.set(i, 1); } } else { if (s[i] == '(') { if (i == 1) { seg.set(i, 0); seg1.set(i, 1); } else { seg.set(i, 0); } } else { if (i == 1) { seg1.set(i, 0); seg.set(i, 1); } else { seg1.set(i, 0); } } } if (i != n) { if (s[i] == s[i + 1]) { if (s[i] == '(') { seg.set(i + 1, 1); } else { seg1.set(i + 1, 1); } } else { if (s[i] == '(') { if (i == 1) { seg.set(i + 1, 0); seg1.set(i + 1, 1); } else { seg.set(i, 0); } } else { if (i == 1) { seg1.set(i, 0); seg.set(i, 1); } else { seg1.set(i, 0); } } } } if (s[i] == '(') { s[i] = ')'; } else { s[i] = '('; } } else { int l, r; cin >> l >> r; r++; int l1, r1 = seg1.min_left(r) + 1; if (s[l] == '('){ l1 = l; cout << min(seg.prod(l1, r1) + 1, seg1.prod(l1, r1)) << endl; } else { int l1 = seg.max_right(l); cout << min(seg.prod(l1, r1), seg1.prod(l1, r1)) << endl; } } } }