QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#706306 | #9537. Chinese Chess | ucup-team1134# | WA | 3ms | 3808kb | C++23 | 12.2kb | 2024-11-03 10:15:50 | 2024-11-03 10:15:51 |
Judging History
answer
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
template<class T>bool chmax(T &a, const T &b) { if (a<b) { a=b; return true; } return false; }
template<class T>bool chmin(T &a, const T &b) { if (b<a) { a=b; return true; } return false; }
#define vi vector<int>
#define vl vector<ll>
#define vii vector<pair<int,int>>
#define vll vector<pair<ll,ll>>
#define vvi vector<vector<int>>
#define vvl vector<vector<ll>>
#define vvii vector<vector<pair<int,int>>>
#define vvll vector<vector<pair<ll,ll>>>
#define vst vector<string>
#define pii pair<int,int>
#define pll pair<ll,ll>
#define pb push_back
#define all(x) (x).begin(),(x).end()
#define mkunique(x) sort(all(x));(x).erase(unique(all(x)),(x).end())
#define fi first
#define se second
#define mp make_pair
#define si(x) int(x.size())
const int mod=998244353,MAX=300005,INF=15<<26;
vi dh[6],dw[6];
string U="JSCMWB";
int dis[6][10][9][10][9];
int H=10,W=9;
void init(){
{
int q=0;
dh[q]={0,1,0,-1};
dw[q]={1,0,-1,0};
}
{
int q=1;
dh[q]={-1,1,1,-1};
dw[q]={1,1,-1,-1};
}
{
int q=2;
for(int h=-9;h<=9;h++){
if(h==0) continue;
dh[q].pb(h);
dw[q].pb(0);
}
for(int w=-8;w<=8;w++){
if(w==0) continue;
dh[q].pb(0);
dw[q].pb(w);
}
}
{
int q=3;
dh[q]={-2,-1,1,2,2,1,-1,-2};
dw[q]={1,2,2,1,-1,-2,-2,-1};
}
{
int q=4;
dh[q]={-2,2,2,-2};
dw[q]={2,2,-2,-2};
}
{
int q=5;
dh[q]={1,0,0};
dw[q]={0,-1,1};
}
for(int q=0;q<6;q++){
for(int i=0;i<H;i++){
for(int j=0;j<W;j++){
for(int s=0;s<H;s++){
for(int t=0;t<W;t++){
dis[q][i][j][s][t]=INF;
}
}
dis[q][i][j][i][j]=0;
queue<pair<int,int>> Q;
Q.push(mp(i,j));
while(!Q.empty()){
auto [h,w]=Q.front();Q.pop();
for(int k=0;k<si(dh[q]);k++){
if(q==5&&h<=4&&k) continue;
int toh=h+dh[q][k],tow=w+dw[q][k];
if(toh<0||toh>=H||tow<0||tow>=W) continue;
if(chmin(dis[q][i][j][toh][tow],dis[q][i][j][h][w]+1)) Q.push({toh,tow});
}
}
for(int s=0;s<H;s++){
for(int t=0;t<W;t++){
if(dis[q][i][j][s][t]==INF) dis[q][i][j][s][t]=-1;
//dis[q][i][j][s][t]=INF;
}
}
}
}
}
}
int main(){
init();
int N;cin>>N;
vii cand;
for(int i=0;i<N;i++){
int a,b;cin>>a>>b;
//a=i/W;b=i%W;
cand.pb(mp(a,b));
}
for(int s1=0;s1<H;s1++){
for(int t1=0;t1<W;t1++){
map<vi,int> MA;
bool ok=true;
for(int q=0;q<6;q++){
for(auto [i,j]:cand){
if(MA.count(vi{dis[q][i][j][s1][t1]})){
if(MA[vi{dis[q][i][j][s1][t1]}]!=q){
ok=false;
}
}
if(!ok) break;
MA[vi{dis[q][i][j][s1][t1]}]=q;
}
if(!ok) break;
}
if(ok){
cout<<1<<endl;
vi X;
cout<<"? "<<s1<<" "<<t1<<endl;
int z;cin>>z;
X.pb(z);
cout<<"! "<<U[MA[X]]<<endl;
return 0;
}
}
}
for(int s1=0;s1<H;s1++){
for(int t1=0;t1<W;t1++){
map<int,vector<array<int,3>>> MA;
bool ff=true;
for(int q=0;q<6;q++){
for(auto [i,j]:cand){
MA[dis[q][i][j][s1][t1]].pb({q,i,j});
}
}
for(auto ddd:MA){
bool ok=false;
for(int s2=0;s2<H;s2++){
for(int t2=0;t2<W;t2++){
bool sei=true;
map<int,int> MA;
for(auto [q,i,j]:ddd.se){
if(MA.count(dis[q][i][j][s2][t2])){
if(MA[dis[q][i][j][s2][t2]]!=q) sei=false;
}
if(!sei) break;
MA[dis[q][i][j][s2][t2]]=q;
}
if(sei){
ok=true;
}
if(ok) break;
}
if(ok) break;
}
ff&=ok;
}
if(ff){
cout<<2<<endl;
cout<<"? "<<s1<<" "<<t1<<endl;
int z;cin>>z;
{
bool ok=false;
for(int s2=0;s2<H;s2++){
for(int t2=0;t2<W;t2++){
bool sei=true;
map<int,int> MAA;
for(auto [q,i,j]:MA[z]){
if(MAA.count(dis[q][i][j][s2][t2])){
if(MAA[dis[q][i][j][s2][t2]]!=q) sei=false;
}
if(!sei) break;
MAA[dis[q][i][j][s2][t2]]=q;
}
if(sei){
cout<<"? "<<s2<<" "<<t2<<endl;
int z;cin>>z;
cout<<"! "<<U[MAA[z]]<<endl;
return 0;
}
}
if(ok) break;
}
}
}
}
}
for(int s1=0;s1<H;s1++){
for(int t1=0;t1<W;t1++){
map<int,vector<array<int,3>>> MA;
bool ff=true;
for(int q=0;q<6;q++){
for(auto [i,j]:cand){
MA[dis[q][i][j][s1][t1]].pb({q,i,j});
}
}
for(auto ddd:MA){
bool ok=false;
for(int s2=0;s2<H;s2++){
for(int t2=0;t2<W;t2++){
for(int s3=0;s3<H;s3++){
for(int t3=0;t3<W;t3++){
bool sei=true;
map<int,int> MA;
for(auto [q,i,j]:ddd.se){
if(MA.count(dis[q][i][j][s2][t2]*10000+dis[q][i][j][s3][t3])){
if(MA[dis[q][i][j][s2][t2]*10000+dis[q][i][j][s3][t3]]!=q) sei=false;
}
if(!sei) break;
MA[dis[q][i][j][s2][t2]*10000+dis[q][i][j][s3][t3]]=q;
}
if(sei){
ok=true;
}
if(ok) break;
}
}
}
if(ok) break;
}
ff&=ok;
}
if(ff){
cout<<3<<endl;
cout<<"? "<<s1<<" "<<t1<<endl;
int z;cin>>z;
{
for(int s2=0;s2<H;s2++){
for(int t2=0;t2<W;t2++){
for(int s3=0;s3<H;s3++){
for(int t3=0;t3<W;t3++){
bool sei=true;
map<int,int> MAA;
for(auto [q,i,j]:MA[z]){
if(MAA.count(dis[q][i][j][s2][t2]*10000+dis[q][i][j][s3][t3])){
if(MAA[dis[q][i][j][s2][t2]*10000+dis[q][i][j][s3][t3]]!=q) sei=false;
}
if(!sei) break;
MAA[dis[q][i][j][s2][t2]*10000+dis[q][i][j][s3][t3]]=q;
}
if(sei){
cout<<"? "<<s2<<" "<<t2<<endl;
int z;cin>>z;
cout<<"? "<<s3<<" "<<t3<<endl;
int zz;cin>>zz;
cout<<"! "<<U[MAA[z*10000+zz]]<<endl;
return 0;
}
}
}
}
}
}
}
}
}
return 0;
for(int s1=0;s1<H;s1++){
for(int t1=0;t1<W;t1++){
for(int s2=0;s2<H;s2++){
for(int t2=0;t2<W;t2++){
for(int s3=0;s3<H;s3++){
for(int t3=0;t3<W;t3++){
if(mp(s1,t1)>=mp(s2,t2)) continue;
if(mp(s2,t2)>=mp(s3,t3)) continue;
map<vi,int> MA;
bool ok=true;
for(int q=0;q<6;q++){
for(auto [i,j]:cand){
if(MA.count(vi{dis[q][i][j][s1][t1],dis[q][i][j][s2][t2],dis[q][i][j][s3][t3]})){
if(MA[vi{dis[q][i][j][s1][t1],dis[q][i][j][s2][t2],dis[q][i][j][s3][t3]}]!=q){
ok=false;
}
}
if(!ok) break;
MA[vi{dis[q][i][j][s1][t1],dis[q][i][j][s2][t2],dis[q][i][j][s3][t3]}]=q;
}
if(!ok) break;
}
if(ok){
cout<<3<<endl;
vi X;
cout<<"? "<<s1<<" "<<t1<<endl;
int z;cin>>z;
X.pb(z);
cout<<"? "<<s2<<" "<<t2<<endl;
cin>>z;
X.pb(z);
cout<<"? "<<s3<<" "<<t3<<endl;
cin>>z;
X.pb(z);
cout<<"! "<<MA[X]<<endl;
return 0;
}
}
}
}
}
}
}
{
vii ans={mp(0,0),mp(0,1),mp(9,0),mp(9,3)};
map<vi,int> MA;
for(int q=0;q<6;q++){
for(auto [i,j]:cand){
vi z;
for(int k=0;k<4;k++){
z.pb(dis[q][i][j][ans[k].fi][ans[k].se]);
}
MA[z]=q;
}
}
if(1){
cout<<4<<endl;
vi X;
for(int k=0;k<4;k++){
cout<<"? "<<ans[k].fi<<" "<<ans[k].se<<endl;
int z;cin>>z;
X.pb(z);
}
cout<<"! "<<MA[X]<<endl;
return 0;
}
}
}
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 3ms
memory: 3808kb
input:
1 9 0 8
output:
1 ? 1 8 ! S
result:
ok number is guessed.
Test #2:
score: 0
Accepted
time: 3ms
memory: 3736kb
input:
4 2 1 2 3 2 5 2 7 5 1
output:
2 ? 0 0 ? 0 6 ! M
result:
ok number is guessed.
Test #3:
score: -100
Wrong Answer
time: 2ms
memory: 3780kb
input:
1 2 4 -1 1
output:
2 ? 0 0 ? 0 2 ! W
result:
wrong answer Token "W" doesn't correspond to pattern "J|S|C|M|X|B"