QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#23039 | #2894. 麻将模拟器 | mahjong | WA | 229ms | 89672kb | C++14 | 6.5kb | 2022-03-11 16:45:53 | 2022-04-30 02:15:24 |
Judging History
answer
#include <bits/stdc++.h>
using namespace std;
int now,dir=1;
int nowpaidui,DP[2000005][5][2],pw[12];
int CNT[2000005];
inline void init()
{
pw[0]=1;
for(int i=1;i<=10;i++) pw[i]=pw[i-1]*5;
for(int i=0;i<=2000000;i++)
{
for(int j=0;j<=4;j++) DP[i][j][0]=DP[i][j][1]=1e9;
int x=i;
while(x) CNT[i]+=x%5,x/=5;
}
DP[0][0][0]=0;
for(int i=0;i<=2000000;i++)
{
for(int x=0;x<=4;x++)
{
for(int y=0;y<=1;y++)
{
if(DP[i][x][y]) continue;
if(!y) for(int k=0;k<=8;k++)
{
int X=(i/pw[k])%5,qwq=(pw[k]);
if(X<=2) DP[i+qwq*2][x][y+1]=min(DP[i+qwq*2][x][y+1],DP[i][x][y]);
}
if(x<4)
{
for(int k=0;k<=8;k++)
{
int X=(i/pw[k])%5,qwq=(pw[k]);
if(X<=1) DP[i+qwq*3][x+1][y]=min(DP[i+qwq*3][x+1][y],DP[i][x][y]);
}
for(int k=0;k<=6;k++)
{
int X=(i/pw[k])%5,Y=(i/pw[k+1])%5,Z=(i/pw[k+2])%5,qwq=(pw[k]);
if(X<=3&&Y<=3&&Z<=3) DP[i+qwq*31][x+1][y]=min(DP[i+qwq*31][x+1][y],DP[i][x][y]);
}
}
}
}
}
for(int i=0;i<=2000000;i++)
{
if(CNT[i]>14) continue;
for(int x=0;x<=4;x++)
{
for(int y=0;y<=1;y++)
{
for(int k=0;k<=8;k++)
{
int X=(i/pw[k])%5,qwq=(pw[k]);
if(X>=1) DP[i][x][y]=min(DP[i-qwq][x][y],DP[i][x][y]);
}
}
}
}
for(int i=2000000;i>=0;i--)
{
if(CNT[i]>14) continue;
for(int x=0;x<=4;x++)
{
for(int y=0;y<=1;y++)
{
for(int k=0;k<=8;k++)
{
int X=(i/pw[k])%5,qwq=(pw[k]);
if(X>=1) DP[i-qwq][x][y]=min(DP[i-qwq][x][y],DP[i][x][y]+1);
}
}
}
}
}
string paidui[200];
inline int trans(string s)
{
if(s=="PASS") return 42;
if(s=="REVERSE") return 44;
if(s=="DOUBLE") return 46;
if(s=="E") return 31;
if(s=="S") return 32;
if(s=="W") return 33;
if(s=="N") return 34;
if(s=="B") return 35;
if(s=="F") return 36;
if(s=="Z") return 37;
if(s[1]=='M') return s[0]-'0';
if(s[1]=='P') return s[0]-'0'+10;
return s[0]-'0'+20;
}
inline string TRANS(int s)
{
if(s==42) return "PASS";
if(s==44) return "REVERSE";
if(s==46) return "DOUBLE";
if(s==31) return "E";
if(s==32) return "S";
if(s==33) return "W";
if(s==34) return "N";
if(s==35) return "B";
if(s==36) return "F";
if(s==37) return "Z";
string rtn;
rtn+=(char)(s%10+'0');
if(s<=10) rtn+='M';
else if(s<=20) rtn+='P';
else rtn+='S';
return rtn;
}
struct pai
{
int cnt[50]={},fulu=0;
string name;
inline int dist()
{
int dp[5][2];
for(int i=0;i<=4;i++) dp[i][0]=dp[i][1]=1e9;
dp[0][0]=0;
int qwq=0;
for(int i=1;i<=9;i++) qwq*=5,qwq+=cnt[i];
for(int i=4;i>=0;i--)
for(int j=1;j>=0;j--)
for(int k=0;k+i<=4;k++)
for(int l=0;l+j<=1;l++)
dp[i+k][j+l]=min(dp[i+k][j+l],dp[i][j]+DP[qwq][k][l]);
qwq=0;
for(int i=11;i<=19;i++) qwq*=5,qwq+=cnt[i];
for(int i=4;i>=0;i--)
for(int j=1;j>=0;j--)
for(int k=0;k+i<=4;k++)
for(int l=0;l+j<=1;l++)
dp[i+k][j+l]=min(dp[i+k][j+l],dp[i][j]+DP[qwq][k][l]);
qwq=0;
for(int i=21;i<=29;i++) qwq*=5,qwq+=cnt[i];
for(int i=4;i>=0;i--)
for(int j=1;j>=0;j--)
for(int k=0;k+i<=4;k++)
for(int l=0;l+j<=1;l++)
dp[i+k][j+l]=min(dp[i+k][j+l],dp[i][j]+DP[qwq][k][l]);
for(int x=31;x<=37;x++)
{
for(int i=4;i>=0;i--) for(int j=1;j>=0;j--)
{
if(i!=4) dp[i+1][j]=min(dp[i+1][j],dp[i][j]+3-min(3,cnt[x]));
if(j!=1) dp[i][j+1]=min(dp[i][j+1],dp[i][j]+2-min(2,cnt[x]));
}
}
return dp[4-fulu][1];
}
inline void zimo()
{
if(dist()==0)
{
cout << name << " " << "SELFDRAWN\n";
cout << name << " " << "WIN\n";
exit(0);
}
}
inline void mopai()
{
if(nowpaidui==148)
{
cout << "DRAW";
exit(0);
}
cout << name+" IN " << paidui[++nowpaidui] << "\n";
++cnt[trans(paidui[nowpaidui])];
zimo();
}
inline int chupai()
{
if(cnt[42])
{
--cnt[42];
now=(now+dir)%4;
now=(now+dir)%4;
return 42;
}
if(cnt[44])
{
--cnt[44];
dir=4-dir;
now=(now+dir)%4;
return 44;
}
if(cnt[46])
{
--cnt[46];
return 46;
}
now=(now+dir)%4;
int mn=1e9,pos=42;
for(int i=40;i>=0;i--)
{
if(cnt[i])
{
--cnt[i];
int x=dist();
++cnt[i];
if(x<mn) mn=x,pos=i;
// if(name=="C") cout << name << " " << x << "qwqwqwqwqwqwqwq" << pos << "\n";
}
}
--cnt[pos];
return pos;
}
inline bool chow(int x)
{
if(x>=30) return 0;
int lst=dist();
if(cnt[x+1]&&cnt[x+2])
{
--cnt[x+1],--cnt[x+2],++fulu;
if(dist()<lst)
{
cout << name << " CHOW " << TRANS(x)+" "+TRANS(x+1)+" "+TRANS(x+2)+"\n";
return 1;
}
++cnt[x+1],++cnt[x+2],--fulu;
}
if(cnt[x+1]&&cnt[x-1])
{
--cnt[x+1],--cnt[x-1],++fulu;
if(dist()<lst)
{
cout << name << " CHOW " << TRANS(x-1)+" "+TRANS(x)+" "+TRANS(x+1)+"\n";
return 1;
}
++cnt[x+1],++cnt[x-1],--fulu;
}
if(cnt[x-2]&&cnt[x-1])
{
--cnt[x-2],--cnt[x-1],++fulu;
if(dist()<lst)
{
cout << name << " CHOW " << TRANS(x-2)+" "+TRANS(x-1)+" "+TRANS(x)+"\n";
return 1;
}
++cnt[x-2],++cnt[x-1],--fulu;
}
return 0;
}
inline void print()
{
for(int i=1;i<=48;i++)
{
for(int j=1;j<=cnt[i];j++)
cout << TRANS(i) << " ";
}
cout << "\n";
}
}a[4];
inline int pong(int x)
{
for(int i=0;i<4;i++)
{
if(a[i].cnt[x]>=2)
{
int lst=a[i].dist();
a[i].cnt[x]-=2;
++a[i].fulu;
if(a[i].dist()>=lst)
{
--a[i].fulu;
a[i].cnt[x]+=2;
}
else
{
cout << a[i].name << " PONG " << TRANS(x)+" "+TRANS(x)+" "+TRANS(x)+"\n";
now=i;
return i;
}
}
}
return -1;
}
inline void ron(int x)
{
for(int i=0;i<4;i++)
{
++a[i].cnt[x];
if(a[i].dist()==0)
{
cout << a[i].name << " " << "RON\n";
cout << a[i].name << " " << "WIN\n";
exit(0);
}
--a[i].cnt[x];
}
}
signed main()
{
a[0].name="A";
a[1].name="B";
a[2].name="C";
a[3].name="D";
init();
for(int i=1;i<=148;i++)
cin >> paidui[i];
now=0,dir=1;
for(int i=1;i<=52;i++)
{
a[now].mopai();
now=(now+dir)%4;
}
// a[0].print();
// cout << a[2].dist() << "**************************";
// cout << DP[pw[2]+pw[3]+pw[4]+pw[6]+pw[8]][1][0] << "\n";
int flag=1;
while(1)
{
if(flag) a[now].mopai();
flag=1;
int lst=now,x=a[now].chupai();
// --a[lst].cnt[x];
cout << a[lst].name << " OUT " << TRANS(x);
if(TRANS(x)=="PASS") cout << " " << a[(lst+dir)%4].name;
cout << "\n";
ron(x);
int nx=pong(x);
if(nx!=-1) now=nx,flag=0;
else if(a[now].chow(x)) flag=0;
}
return 0;
}
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 229ms
memory: 89608kb
input:
8M Z E 9P 3P 9S 5P W 3M 8P DOUBLE 5P Z 2P 3M 8S 2S 5P 5M E 6M 9S 6P 5S 7M 4S 3S 6M 3S 2M 9M 5S Z 7P 5P 8M 3M F 7M 2S N 4P 3S S PASS 1P 6S 3P 9P 9S 4M 8P N Z N 5M DOUBLE REVERSE S 3P 4M 4S 1S PASS 4P 6S 7S 7P 6S 9M REVERSE 3P 7P DOUBLE B 9P 4S 5S 7S 7S 7P 6S 9S B 9M S F 2P 1P PASS 9P DOUBLE 4P PASS 5...
output:
A IN 8M B IN Z C IN E D IN 9P A IN 3P B IN 9S C IN 5P D IN W A IN 3M B IN 8P C IN DOUBLE D IN 5P A IN Z B IN 2P C IN 3M D IN 8S A IN 2S B IN 5P C IN 5M D IN E A IN 6M B IN 9S C IN 6P D IN 5S A IN 7M B IN 4S C IN 3S D IN 6M A IN 3S B IN 2M C IN 9M D IN 5S A IN Z B IN 7P C IN 5P D IN 8M A IN 3M B IN F...
result:
ok 84 lines
Test #2:
score: 0
Accepted
time: 199ms
memory: 89472kb
input:
REVERSE 4S 8S 6P 4P F 1P W 9P N 9M B 7S 5P PASS 5M 7M 9S 1S 2P 3S 6S B 2S 9P 9M 4S 3M W 6P 8P W 2M 7P 6M 8M 2S S F W DOUBLE E 2P E 2M 8S 2S 9P 1M 7S 8M N 4P 1S 1P S 3P 3S B 3M 7P 5S 3M 5M 7M 2S E 9P 1M 7P 3P 5P REVERSE 5S 9S 8M 4M 7P 1S 7M 1M 1M 8P 9S 6M 7S PASS 4M 3M 9M B 2P 4P 6S F 4S 6P 6P 7M 1S ...
output:
A IN REVERSE B IN 4S C IN 8S D IN 6P A IN 4P B IN F C IN 1P D IN W A IN 9P B IN N C IN 9M D IN B A IN 7S B IN 5P C IN PASS D IN 5M A IN 7M B IN 9S C IN 1S D IN 2P A IN 3S B IN 6S C IN B D IN 2S A IN 9P B IN 9M C IN 4S D IN 3M A IN W B IN 6P C IN 8P D IN W A IN 2M B IN 7P C IN 6M D IN 8M A IN 2S B IN...
result:
ok 175 lines
Test #3:
score: 0
Accepted
time: 205ms
memory: 89672kb
input:
6M 5S 2S 8S 5S N W 5S 6P 9P 3S 6S 8P 7P 5M 5M 7M 2S 4S 5M REVERSE F 9S REVERSE 7S B 2S 4M 3S 6P 2P 3M N 8M 9M REVERSE 7P PASS 2S 1P 1M N 8M 7M W 1S 4M 2M PASS W 6P 7M 7P 3P 9S 4M B 4S 6M 8S 6S 3P 2M 9S 9S 1S 1M 1P 2P 1S 2P 4P 9P 8P S 9M F 7S 1M 9P E S 8P Z 8M 1P 2M F 4P B DOUBLE 4S E 3P 7S DOUBLE 9P...
output:
A IN 6M B IN 5S C IN 2S D IN 8S A IN 5S B IN N C IN W D IN 5S A IN 6P B IN 9P C IN 3S D IN 6S A IN 8P B IN 7P C IN 5M D IN 5M A IN 7M B IN 2S C IN 4S D IN 5M A IN REVERSE B IN F C IN 9S D IN REVERSE A IN 7S B IN B C IN 2S D IN 4M A IN 3S B IN 6P C IN 2P D IN 3M A IN N B IN 8M C IN 9M D IN REVERSE A ...
result:
ok 168 lines
Test #4:
score: 0
Accepted
time: 208ms
memory: 89612kb
input:
6S 2S 5M 8P 5P F B F 3S 8P 5P 9M 4S 6S 3S Z S 2P 2M 4S 2P 9S 4S 4P 2S 7S REVERSE 3M 2M E 9P 4P 9P W E 6P PASS S 2M 1M 3S B 7M 3P 7S DOUBLE 1S 6M 6P Z 3P 5P 7S 9M 2P 6S W 1M S E REVERSE 1M 9M W PASS 1P N E 7P 1P F 9S 9S 1P W 8P 3P N 3P DOUBLE 4M 6M 2S 4M 1P REVERSE Z B 6M F 7M 5M 4M 3M 3S S DOUBLE N ...
output:
A IN 6S B IN 2S C IN 5M D IN 8P A IN 5P B IN F C IN B D IN F A IN 3S B IN 8P C IN 5P D IN 9M A IN 4S B IN 6S C IN 3S D IN Z A IN S B IN 2P C IN 2M D IN 4S A IN 2P B IN 9S C IN 4S D IN 4P A IN 2S B IN 7S C IN REVERSE D IN 3M A IN 2M B IN E C IN 9P D IN 4P A IN 9P B IN W C IN E D IN 6P A IN PASS B IN ...
result:
ok 128 lines
Test #5:
score: -100
Wrong Answer
time: 198ms
memory: 89600kb
input:
5P 2P 5M PASS 3S 8M W S W DOUBLE 9M E 6S 9S Z 4S W 3S 6M 6S DOUBLE 7M 1P 9M 9S Z 9P REVERSE 7M 1S 8S 2S 8P DOUBLE 4S 4M 6S 3P 4S 3P 8S REVERSE 1M N 7M 8S 3P 6M 5P 3S REVERSE 6P N 6P 4P PASS E 8P N 1S 9S 8M 7S 8P 3P 5M 6M 6M 9S 2M 6P E 8P PASS 2P F 3M N 1M 3M B F 1P 1P 1S F 2S 5M 2S 4S 2M 4M 1M 2P 7P...
output:
A IN 5P B IN 2P C IN 5M D IN PASS A IN 3S B IN 8M C IN W D IN S A IN W B IN DOUBLE C IN 9M D IN E A IN 6S B IN 9S C IN Z D IN 4S A IN W B IN 3S C IN 6M D IN 6S A IN DOUBLE B IN 7M C IN 1P D IN 9M A IN 9S B IN Z C IN 9P D IN REVERSE A IN 7M B IN 1S C IN 8S D IN 2S A IN 8P B IN DOUBLE C IN 4S D IN 4M ...
result:
wrong answer 55th lines differ - expected: 'A IN 6P', found: 'B PONG DOUBLE DOUBLE DOUBLE'