This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
int ask(int i){
cout << "? " << i << " " << 1 << " " << 1 << endl;
int x; cin >> x;
return x;
}
int main(){
int N, M, K, Q; cin >> N >> M >> K >> Q;
vector <int> v(N+1, -1);
v[0] = 0; v[N] = 0;
int s = 1, e = N, m;
while (e >= s){
m = (e+s)/2;
if (s == e){cout << "! " << m << " " << 1 << " " << 1 << endl; return 0;}
int a = v[m], b = v[m+1];
if (a == -1){a = ask(m); v[m] = a;}
if (b == -1){b = ask(m+1); v[m+1] = b;}
if (a >= b)e = m;
else s = m+1;
}
}
# | 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... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |