QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#208031 | #5156. Going in Circles | Minhho | WA | 12ms | 3760kb | C++20 | 1.4kb | 2023-10-09 03:57:56 | 2023-10-09 03:57:57 |
Judging History
answer
#define taskname "G"
#include <bits/stdc++.h>
#define int long long
using namespace std;
const string l = "? left", r = "? right", f = "? flip";
int x;
mt19937 rng(chrono::high_resolution_clock::now().time_since_epoch().count());
void checksmall()
{
for (int i=1; i<=50; i++)
{
cout<<l<<endl;
cin>>x;
if (x) cout<<f<<endl, cin>>x;
}
cout<<f<<endl;
cin>>x;
for (int i=1; i<=50; i++)
{
cout<<r<<endl;
cin>>x;
if (x)
{
cout<<"! "<<i;
exit(0);
}
}
}
signed main()
{
ios_base::sync_with_stdio(false);
cin.tie(nullptr); cout.tie(nullptr);
cin>>x;
if (x) cout<<f<<endl, cin>>x;
checksmall();
int rnd = 0, rrnd = 0;
for (int i=0; i<=29; i++)
{
int x = rng() & 1;
rnd += x * (1ll<<i);
if (i < 29) rrnd += x * (1ll<<i);
}
// cout<<rnd<<"\n";
// cout<<(rnd << 1) % (1ll << 30);
// cout<<rnd % (1ll<<29)<<" "<<rrnd<<" "<<(((rnd<<1) % (1ll<<30))|(rnd&1))<<"\n";
for (int i=0; i<30; i++)
{
cout<<l<<endl;
cin>>x;
if (x != (rnd >> (29-i)) & 1) cout<<f<<endl, cin>>x;
}
int cur = rnd, cnt = 0;
for (int i=1; i<=1e5; i++)
{
cnt++;
cout<<l<<endl;
cin>>x;
cur = (cur << 1) % (1ll<<30);
cur |= x;
if (cur == rnd) return cout<<"! "<<cnt, 0;
}
}
詳細信息
Test #1:
score: 0
Wrong Answer
time: 12ms
memory: 3760kb
input:
0 1 0 0 1 0 0 1 0 0 1 0 1 0 0 0 0 0 0 0 0 1 0 0 0 1 0 0 1 0 0 1 0 0 1 0 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 0 1 0 0 0 1 0 1 0 1 0 1 0 1 0 0 1 0 0 1 0 0 0 1 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 0 1 ...
output:
? left ? flip ? left ? left ? flip ? left ? left ? flip ? left ? left ? flip ? left ? flip ? left ? left ? left ? left ? left ? left ? left ? left ? flip ? left ? left ? left ? flip ? left ? left ? flip ? left ? left ? flip ? left ? left ? flip ? left ? left ? flip ? left ? flip ? left ? flip ? left...
result:
wrong answer Wrong answer: used too many queries. Queries used: 26001 (10501 too many, terminated)