QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#208014 | #5156. Going in Circles | Minhho | TL | 0ms | 0kb | C++20 | 1.2kb | 2023-10-09 03:32:59 | 2023-10-09 03:33:00 |
answer
#define taskname "G"
#include <bits/stdc++.h>
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;
for (int i=0; i<=29; i++)
{
int x = rng() & 1;
rnd += x * (1ll<<i);
}
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;
while (true)
{
cnt++;
cout<<l<<endl;
cin>>x;
cur %= (1ll<<29);
cur <<= 1;
cur |= x;
if (cur == rnd) return cout<<"! "<<cnt, 0;
}
}
详细
Test #1:
score: 0
Time Limit Exceeded
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 0 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...