Submission #312545

#TimeUsernameProblemLanguageResultExecution timeMemory
312545model_codeZagrade (COI20_zagrade)C++17
100 / 100
1012 ms1040 KiB
#include <bits/stdc++.h> using namespace std; #define TRACE(x) cerr << #x << " " << x << endl #define FOR(i, a, b) for (int i = (a); i < int(b); ++i) #define REP(i, n) FOR(i, 0, n) #define _ << " " << const int MAXN = 1e5 + 10; int n, q; char sol[MAXN]; int ask(int a, int b) { printf("? %d %d\n", a + 1, b + 1); fflush(stdout); int ret; scanf("%d", &ret); return ret; } int ans() { printf("! %s\n", sol); fflush(stdout); exit(0); } int main(void) { scanf("%d %d", &n, &q); stack<int> S; for (int i = 0; i < n; ++i) { if (S.empty()) { S.push(i); continue; } int ok = ask(S.top(), i); if (ok) { sol[S.top()] = '('; sol[i] = ')'; S.pop(); } else { S.push(i); } } assert(S.size() % 2 == 0); int x = (int) S.size() / 2; for (int i = 0; i < x; ++i) { sol[S.top()] = '('; S.pop(); } for (int i = 0; i < x; ++i) { sol[S.top()] = ')'; S.pop(); } ans(); return 0; }

Compilation message (stderr)

zagrade.cpp: In function 'int ask(int, int)':
zagrade.cpp:19:8: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   19 |   scanf("%d", &ret);
      |   ~~~~~^~~~~~~~~~~~
zagrade.cpp: In function 'int main()':
zagrade.cpp:30:8: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   30 |   scanf("%d %d", &n, &q);
      |   ~~~~~^~~~~~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...