QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#378479 | #6394. Turn on the Light | Aprilend# | WA | 1ms | 3700kb | C++14 | 1.5kb | 2024-04-06 13:09:12 | 2024-04-06 13:09:15 |
Judging History
answer
#include<bits/stdc++.h>
using namespace std;
#define edl '\n'
#define re return
#define gcd __gcd
#define db double
#define fir first
#define sec second
#define MAX 1000006
#define ll long long
#define i64 __int128
#define inf 2147483647
#define MAXN 100000009
#define pll pair<ll,ll>
#define pb push_back
#define vint vector<int>
#define pii pair<int,int>
#define ANS cout<<ans<<edl
#define No cout<<"No"<<edl
#define NO cout<<"NO"<<edl
#define hhh cout<<"hhh"<<edl
#define Yes cout<<"Yes"<<edl
#define YES cout<<"YES"<<edl
#define all(a,l,r) a+l,a+1+r
#define ull unsigned long long
#define INF 9223372036854775807
#define vpii vector<pair<int,int>>
#define sp(x) fixed << setprecision(x)
#define FOR(i,l,r) for(auto(i)=(l);(i)<=(r);++(i))
const ll mod = 1000000007;
ll qpow(ll n,ll m,ll mod)
{
ll ans=1;if(n>mod) n%=mod;
while(m>0){if(m&1) {ans*=n;ans%=mod;}
n*=n; n%=mod; m>>=1;} return ans;
}
int pre, now, l, r;
int ck(int mid) {
int t;
cout<<"? "<<mid<<endl;
cin>>pre;
cout<<"? "<<l<<endl;
cin>>now;
if(now>pre) re 1;
else if(now==pre) re 2;
else if(now<pre) re 3;
}
void Solve(void)
{
int n; cin>>n;
l=1, r=n;
while(l <= r) {
ll mid = l + r >> 1;
int t=ck(mid);
if(t==1) l=mid+1;
else if(t==2) {
cout<<"! "<<l<<endl;
re;
}
else r=mid-1;
}
cout.flush();
}
int main(void)
{
std::ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);
int _=1;
// cin>>_;
while(_--)
Solve ();
return 0;
}
详细
Test #1:
score: 100
Accepted
time: 0ms
memory: 3700kb
input:
3 1 2 2 2
output:
? 2 ? 1 ? 3 ? 3 ! 3
result:
ok Correct position at 3
Test #2:
score: -100
Wrong Answer
time: 1ms
memory: 3680kb
input:
10 1 2 3 4 5 5
output:
? 5 ? 1 ? 8 ? 6 ? 9 ? 9 ! 9
result:
wrong answer Wrong favorite light!