QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#23039#2894. 麻将模拟器mahjongWA 229ms89672kbC++146.5kb2022-03-11 16:45:532022-04-30 02:15:24

Judging History

你现在查看的是最新测评结果

  • [2023-08-10 23:21:45]
  • System Update: QOJ starts to keep a history of the judgings of all the submissions.
  • [2022-04-30 02:15:24]
  • 评测
  • 测评结果:WA
  • 用时:229ms
  • 内存:89672kb
  • [2022-03-11 16:45:53]
  • 提交

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'