#include <bits/stdc++.h>
using namespace std;
#define int long long
int n, q;
char ch[100005];
int ask(int i, int j) {
	cout << "? " << i << ' ' << j << endl;
	int res; cin >> res;
	return res;
}
int32_t main() {
	cin >> n >> q;
	for (int i = 1; i <= n; i++) ch[i] = '.';
	for (int i = 1; i < n; i++) {
		if (ch[i] != '.') continue;
		for (int j = i + 1; j <= n; j += 2) {
			if (ch[j] != '.') continue;
			if (q < 0) return 0;
			q--;
			int res = ask(i, j);
			if (res) {
				ch[i] = '(';
				ch[j] = ')';
			}
		}
	}
	int cnt = 0;
	for (int i = 1; i <= n; i++) if (ch[i] == ')') cnt++;
	string s = "";
	for (int i = 1; i <= n; i++) {
		if (ch[i] != '.') s += ch[i];
		else if (cnt * 2 < n) {
			s += ')';
			cnt++;
		} else s += '(';
	}
	cout << "! " << s << endl;
}
| # | Verdict  | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict  | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict  | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict  | Execution time | Memory | Grader output | 
|---|
| Fetching results... |