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 "minerals.h"
#include <vector>
#include <stdio.h>
//using namespace std;
int ans[86005]={0};
bool have[86005];
int cha[86005];
void Solve(int N)
{
int x=0,y,i,j,now=1,tt=0;
for(i=1;i<=2*N;i++)
{
y=Query(i);
tt++;
if(y-x==0)
{
cha[now++]=i;
have[i]=1;
}
x=y;
}
for(i=1;i<=2*N;i++)
{
tt++;
if(have[i]==0) cha[now++]=i;
else Query(i);
}
for(i=0;i<16;i++)
{
for(j=1;j<=N;j++)
{
if((j&(1<<i))&&(i==0||(j&(1<<(i-1)))==0))
{
x=Query(cha[j]);
tt++;
}
}
for(j=1;j<=N;j++)
{
y=Query(cha[j+N]);
tt++;
if(y-x==0) ans[j]+=(1<<i);
x=y;
}
for(j=1;j<=N;j++)
{
if((j&(1<<i))&&(j&(1<<(i+1)))==0&&i!=15)
{
x=Query(cha[j]);
tt++;
}
}
}
//printf("%d\n",tt);
for(i=1;i<=N;i++)
{
Answer(cha[i+N],cha[ans[i]]);
}
}
# | 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... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |