# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
1151439 | thunopro | Mađioničar (COI22_madionicar) | C++20 | 465 ms | 408 KiB |
#include <bits/stdc++.h>
using namespace std;
int N;
int ask(int l, int r) {
printf("? %d %d\n", l + 1, r + 1);
fflush(stdout);
int ret;
scanf("%d", &ret);
return ret;
}
void ans(int L) {
printf("! %d\n", L);
fflush(stdout);
}
int main(void) {
scanf("%d", &N);
int r_odd = 0, r_even = 0;
for (int i = 0; i < N; ++i) {
while (i - r_odd - 1 >= 0 && i + r_odd + 1 < N && ask(i - r_odd - 1, i + r_odd + 1)) ++r_odd;
while (i - r_even >= 0 && i + r_even + 1 < N && ask(i - r_even, i + r_even + 1)) ++r_even;
}
ans(max(2 * r_odd + 1, 2 * r_even));
return 0;
}
컴파일 시 표준 에러 (stderr) 메시지
# | 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... |