QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#117247 | #6668. Trokuti | kshitij_sodani | 0 | 27ms | 7576kb | C++14 | 2.9kb | 2023-06-30 19:19:38 | 2023-06-30 19:19:40 |
Judging History
answer
#include <bits/stdc++.h>
using namespace std;
#define a first
#define b second
#define pb push_back
typedef long long llo;
//#define endl '\n'
int ans[101][101];
int vis[101][101][101];
int val[101][101];
int su=0;
int query(int aa,int bb,int cc){
int x=min(aa,min(bb,cc));
int y=max(aa,max(bb,cc));
int z=aa;
if(z==x or z==y){
z=bb;
}
if(z==x or z==y){
z=cc;
}
if(vis[x][z][y]>=0){
return vis[x][z][y];
}
cout<<"? "<<x+1<<" "<<z+1<<" "<<y+1<<endl;
int xx;
xx=val[x][y]+val[y][z]+val[z][x];;
cin>>xx;
su++;
vis[x][z][y]=xx;
return xx;
}
void set2(int i,int j,int k){
ans[i][j]=k;
ans[j][i]=k;
}
mt19937 rng;
vector<int> cur;
void solve(int i,vector<int> tt){
shuffle(tt.begin(),tt.end(),rng);
vector<pair<int,int>> ee;
for(int j=0;j<tt.size();j+=2){
if(j+1==tt.size()){
set2(i,tt[j],query(cur[0],i,tt[j])-ans[cur[0]][i]-ans[cur[0]][tt[j]]);
}
else{
int x=query(i,tt[j],tt[j+1])-ans[tt[j]][tt[j+1]];
if(x==0){
set2(i,tt[j],0);
set2(i,tt[j+1],0);
}
else if(x==2){
set2(i,tt[j],1);
set2(i,tt[j+1],1);
}
else{
ee.pb({tt[j],tt[j+1]});
}
}
}
if(ee.size()){
vector<int> ff;
for(auto j:ee){
ff.pb(j.a);
}
solve(i,ff);
for(int j=0;j<ee.size();j++){
set2(i,ee[j].b,1-ans[i][ee[j].a]);
}
}
}
int main(){
ios_base::sync_with_stdio(false);
cin.tie(NULL);
int n=100;
for(int i=0;i<n;i++){
for(int j=0;j<n;j++){
for(int k=0;k<n;k++){
vis[i][j][k]=-1;
}
}
}
rng=mt19937(chrono::steady_clock::now().time_since_epoch().count());
for(int i=0;i<n;i++){
for(int j=i+1;j<n;j++){
val[i][j]=rng()%2;
val[j][i]=val[i][j];
}
}
for(int i=0;i<6;i++){
for(int j=i+1;j<6;j++){
for(int k=j+1;k<6;k++){
query(i,j,k);
//cout<<vis[i][j][k]<<":"<<endl;
if(vis[i][j][k]==0 or vis[i][j][k]==3 and cur.size()==0){
cur.pb(i);
cur.pb(j);
cur.pb(k);
int z=1;
if(vis[i][j][k]==0){
z=0;
}
set2(i,j,z);
set2(i,k,z);
set2(j,k,z);
}
}
}
}
/*cout<<11<<endl;
for(auto j:cur){
cout<<j<<",";
}
cout<<endl;
return 0;*/
vector<int> tt;
shuffle(cur.begin(),cur.end(),rng);
for(int i=0;i<n;i++){
if(i==cur[0] or i==cur[1] or i==cur[2]){
continue;
}
int aa=query(i,cur[0],cur[1])-ans[cur[0]][cur[1]];
int bb=query(i,cur[1],cur[2])-ans[cur[1]][cur[2]];
int cc=query(i,cur[2],cur[0])-ans[cur[2]][cur[0]];
int su=(aa+bb+cc)/2;
set2(i,cur[2],su-aa);
set2(i,cur[0],su-bb);
set2(i,cur[1],su-cc);
}
for(int i=0;i<n;i++){
if(i==cur[0] or i==cur[1] or i==cur[2]){
continue;
}
solve(i,tt);
tt.pb(i);
}
cout<<"!"<<endl;
for(int i=0;i<n;i++){
for(int j=0;j<n;j++){
//assert(ans[i][j]==val[i][j]);
cout<<ans[i][j];
}
cout<<endl;
}
// cout<<su<<endl;
return 0;
}
详细
Subtask #1:
score: 0
Wrong Answer
Test #1:
score: 100
Accepted
time: 27ms
memory: 7576kb
input:
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 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 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 ...
output:
? 1 2 3 ? 1 2 4 ? 1 2 5 ? 1 2 6 ? 1 3 4 ? 1 3 5 ? 1 3 6 ? 1 4 5 ? 1 4 6 ? 1 5 6 ? 2 3 4 ? 2 3 5 ? 2 3 6 ? 2 4 5 ? 2 4 6 ? 2 5 6 ? 3 4 5 ? 3 4 6 ? 3 5 6 ? 4 5 6 ? 1 4 4 ? 2 4 4 ? 3 4 4 ? 4 4 6 ? 4 4 7 ? 4 5 7 ? 4 4 8 ? 4 5 8 ? 4 4 9 ? 4 5 9 ? 4 4 10 ? 4 5 10 ? 4 4 11 ? 4 5 11 ? 4 4 12 ? 4 5 12 ? 4 4 ...
result:
points 1.0 points 1.0 correct 2609 queries
Test #2:
score: 100
Accepted
time: 1ms
memory: 7576kb
input:
3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 ...
output:
? 1 2 3 ? 1 2 4 ? 1 2 5 ? 1 2 6 ? 1 3 4 ? 1 3 5 ? 1 3 6 ? 1 4 5 ? 1 4 6 ? 1 5 6 ? 2 3 4 ? 2 3 5 ? 2 3 6 ? 2 4 5 ? 2 4 6 ? 2 5 6 ? 3 4 5 ? 3 4 6 ? 3 5 6 ? 4 5 6 ? 2 3 7 ? 1 2 7 ? 1 3 7 ? 2 3 8 ? 1 2 8 ? 1 3 8 ? 2 3 9 ? 1 2 9 ? 1 3 9 ? 2 3 10 ? 1 2 10 ? 1 3 10 ? 2 3 11 ? 1 2 11 ? 1 3 11 ? 2 3 12 ? 1 2...
result:
points 1.0 points 1.0 correct 2652 queries
Test #3:
score: 100
Accepted
time: 4ms
memory: 7476kb
input:
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 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 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 ...
output:
? 1 2 3 ? 1 2 4 ? 1 2 5 ? 1 2 6 ? 1 3 4 ? 1 3 5 ? 1 3 6 ? 1 4 5 ? 1 4 6 ? 1 5 6 ? 2 3 4 ? 2 3 5 ? 2 3 6 ? 2 4 5 ? 2 4 6 ? 2 5 6 ? 3 4 5 ? 3 4 6 ? 3 5 6 ? 4 5 6 ? 1 2 2 ? 2 2 3 ? 2 2 5 ? 2 2 6 ? 2 4 7 ? 2 2 7 ? 2 4 8 ? 2 2 8 ? 2 4 9 ? 2 2 9 ? 2 4 10 ? 2 2 10 ? 2 4 11 ? 2 2 11 ? 2 4 12 ? 2 2 12 ? 2 4 ...
result:
points 1.0 points 1.0 correct 2610 queries
Test #4:
score: 100
Accepted
time: 0ms
memory: 7552kb
input:
3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 ...
output:
? 1 2 3 ? 1 2 4 ? 1 2 5 ? 1 2 6 ? 1 3 4 ? 1 3 5 ? 1 3 6 ? 1 4 5 ? 1 4 6 ? 1 5 6 ? 2 3 4 ? 2 3 5 ? 2 3 6 ? 2 4 5 ? 2 4 6 ? 2 5 6 ? 3 4 5 ? 3 4 6 ? 3 5 6 ? 4 5 6 ? 2 3 7 ? 1 2 7 ? 1 3 7 ? 2 3 8 ? 1 2 8 ? 1 3 8 ? 2 3 9 ? 1 2 9 ? 1 3 9 ? 2 3 10 ? 1 2 10 ? 1 3 10 ? 2 3 11 ? 1 2 11 ? 1 3 11 ? 2 3 12 ? 1 2...
result:
points 1.0 points 1.0 correct 2653 queries
Test #5:
score: 100
Accepted
time: 10ms
memory: 7500kb
input:
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 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 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 ...
output:
? 1 2 3 ? 1 2 4 ? 1 2 5 ? 1 2 6 ? 1 3 4 ? 1 3 5 ? 1 3 6 ? 1 4 5 ? 1 4 6 ? 1 5 6 ? 2 3 4 ? 2 3 5 ? 2 3 6 ? 2 4 5 ? 2 4 6 ? 2 5 6 ? 3 4 5 ? 3 4 6 ? 3 5 6 ? 4 5 6 ? 4 6 7 ? 3 6 7 ? 3 4 7 ? 4 6 8 ? 3 6 8 ? 3 4 8 ? 4 6 9 ? 3 6 9 ? 3 4 9 ? 4 6 10 ? 3 6 10 ? 3 4 10 ? 4 6 11 ? 3 6 11 ? 3 4 11 ? 4 6 12 ? 3 6...
result:
points 1.0 points 1.0 correct 2660 queries
Test #6:
score: 100
Accepted
time: 17ms
memory: 7548kb
input:
3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 3 ...
output:
? 1 2 3 ? 1 2 4 ? 1 2 5 ? 1 2 6 ? 1 3 4 ? 1 3 5 ? 1 3 6 ? 1 4 5 ? 1 4 6 ? 1 5 6 ? 2 3 4 ? 2 3 5 ? 2 3 6 ? 2 4 5 ? 2 4 6 ? 2 5 6 ? 3 4 5 ? 3 4 6 ? 3 5 6 ? 4 5 6 ? 1 2 7 ? 1 3 7 ? 2 3 7 ? 1 2 8 ? 1 3 8 ? 2 3 8 ? 1 2 9 ? 1 3 9 ? 2 3 9 ? 1 2 10 ? 1 3 10 ? 2 3 10 ? 1 2 11 ? 1 3 11 ? 2 3 11 ? 1 2 12 ? 1 3...
result:
points 1.0 points 1.0 correct 2662 queries
Test #7:
score: 100
Accepted
time: 4ms
memory: 7480kb
input:
0 0 1 0 0 1 1 1 0 1 0 0 1 0 0 0 0 1 1 0 0 0 0 0 0 1 2 2 2 2 0 0 0 0 0 0 0 0 0 0 2 1 2 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 1 0 0 0 0 0 0 0 0 2 1 0 0 0 0 0 0 0 1 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 1 0 1 2 2 0 0 0 0 0 1 2 2 0 0 2 1 0 0 0 0 2 2 0 0 0 1 2 2 0 0 0 0 0 0 2 2 0 1 0 0 2 1 0 1 0 0 2 1 0 0 0 0 2 1 ...
output:
? 1 2 3 ? 1 2 4 ? 1 2 5 ? 1 2 6 ? 1 3 4 ? 1 3 5 ? 1 3 6 ? 1 4 5 ? 1 4 6 ? 1 5 6 ? 2 3 4 ? 2 3 5 ? 2 3 6 ? 2 4 5 ? 2 4 6 ? 2 5 6 ? 3 4 5 ? 3 4 6 ? 3 5 6 ? 4 5 6 ? 1 2 2 ? 2 2 3 ? 2 2 4 ? 2 2 6 ? 2 2 7 ? 2 5 7 ? 2 2 8 ? 2 5 8 ? 2 2 9 ? 2 5 9 ? 2 2 10 ? 2 5 10 ? 2 2 11 ? 2 5 11 ? 2 2 12 ? 2 5 12 ? 2 2 ...
result:
points 1.0 points 1.0 correct 3244 queries
Test #8:
score: 100
Accepted
time: 23ms
memory: 7488kb
input:
3 1 2 1 1 2 1 1 0 1 1 1 1 0 0 0 0 0 0 0 0 0 0 0 2 2 0 0 2 2 2 1 0 1 0 0 2 1 2 2 2 1 0 1 0 0 0 0 2 2 0 1 2 2 0 1 0 0 2 2 0 0 0 1 0 0 2 1 0 1 2 1 2 2 0 1 0 0 0 0 0 0 0 1 0 0 0 1 0 0 0 0 2 1 0 0 0 0 2 2 0 0 2 1 0 1 0 0 2 2 0 0 0 1 0 0 0 1 0 0 0 0 2 1 0 1 0 1 0 0 0 1 0 1 2 1 2 1 2 2 0 0 2 1 0 1 0 0 0 0 ...
output:
? 1 2 3 ? 1 2 4 ? 1 2 5 ? 1 2 6 ? 1 3 4 ? 1 3 5 ? 1 3 6 ? 1 4 5 ? 1 4 6 ? 1 5 6 ? 2 3 4 ? 2 3 5 ? 2 3 6 ? 2 4 5 ? 2 4 6 ? 2 5 6 ? 3 4 5 ? 3 4 6 ? 3 5 6 ? 4 5 6 ? 1 6 6 ? 2 6 6 ? 3 6 6 ? 5 6 6 ? 6 6 7 ? 4 6 7 ? 6 6 8 ? 4 6 8 ? 6 6 9 ? 4 6 9 ? 6 6 10 ? 4 6 10 ? 6 6 11 ? 4 6 11 ? 6 6 12 ? 4 6 12 ? 6 6 ...
result:
points 1.0 points 1.0 correct 3357 queries
Test #9:
score: 0
Wrong Answer
time: 22ms
memory: 7548kb
input:
2 2 2 2 3 3 3 2 2 3 1 1 1 0 0 1 2 2 3 1 1 1 3 1 1 3 1 1 3 1 1 3 1 1 3 1 1 3 1 1 3 1 1 3 1 1 3 1 1 3 1 1 3 1 1 3 1 1 3 1 1 3 1 1 3 1 1 3 1 1 3 1 1 3 1 1 3 1 1 3 1 1 3 1 1 3 1 1 3 1 1 3 1 1 3 1 1 3 1 1 3 1 1 3 1 1 3 1 1 3 1 1 3 1 1 3 1 1 3 1 1 3 1 1 3 1 1 3 1 1 3 1 1 3 1 1 3 1 1 3 1 1 3 1 1 3 1 1 3 1 ...
output:
? 1 2 3 ? 1 2 4 ? 1 2 5 ? 1 2 6 ? 1 3 4 ? 1 3 5 ? 1 3 6 ? 1 4 5 ? 1 4 6 ? 1 5 6 ? 2 3 4 ? 2 3 5 ? 2 3 6 ? 2 4 5 ? 2 4 6 ? 2 5 6 ? 3 4 5 ? 3 4 6 ? 3 5 6 ? 4 5 6 ? 2 3 7 ? 2 5 7 ? 3 5 7 ? 2 3 8 ? 2 5 8 ? 3 5 8 ? 2 3 9 ? 2 5 9 ? 3 5 9 ? 2 3 10 ? 2 5 10 ? 3 5 10 ? 2 3 11 ? 2 5 11 ? 3 5 11 ? 2 3 12 ? 2 5...
result:
wrong answer Token parameter [name=ans_i] equals to "000-10-1-1-1-1-1-1-1-1-1-1-1-1...1-1-1-1-1-1-1-1-1-1-1-1-1-1-1-1", doesn't correspond to pattern "[01]{100,100}"