QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#664665#3686. 麻将fairyqq28100 ✓203ms4484kbC++143.6kb2024-10-21 21:39:082024-10-21 21:39:08

Judging History

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

  • [2024-10-21 21:39:08]
  • 评测
  • 测评结果:100
  • 用时:203ms
  • 内存:4484kb
  • [2024-10-21 21:39:08]
  • 提交

answer

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<string>
#include<cstring>
#include<unordered_map>
#include<cassert>
#define rep(i, a, b) for(int i = (a); i <= (b); i++)
#define per(i, a, b) for(int i = (a); i >= (b); i--)
using namespace std;
typedef long long ll;
const int N = 40, lim = 33;
int n;
const string ch[] = {"1m","2m","3m","4m","5m","6m","7m","8m","9m","1s","2s","3s","4s","5s","6s","7s","8s","9s","1p","2p","3p","4p","5p","6p","7p","8p","9p","1c","2c","3c","4c","5c","6c","7c"};
int cnt[N];
ll C[140][20];
int id(string s){
	rep(i, 0, lim) if(s == ch[i]) return i;
	return -1;
}
void init(){
	rep(i, 0, 136){
		C[i][0] = 1;
		rep(j, 1, min(i, 14)) C[i][j] = C[i-1][j-1] + C[i-1][j];
	}
}
ll solve1(){
	static ll f[10];
	memset(f, 0, sizeof(f));
	f[0] = 1;
	rep(i, 0, lim) if(cnt[i] > 1)
		per(j, 7, 1) f[j] += f[j-1] * C[cnt[i]][2];
	return f[7];
}
bool check9(int x) {return ch[x][0]=='1' || ch[x][0]=='9' || ch[x][1] == 'c';}
ll solve2(){
	static ll f[20][2];
	memset(f, 0, sizeof(f));
	f[0][0] = 1;
	rep(i, 0, lim) if(cnt[i] && check9(i)){
		per(j, 14, 1) f[j][1] += f[j-1][1] * cnt[i];
		rep(j, 2, 14) f[j][1] += f[j-2][0] * C[cnt[i]][2];
		per(j, 14, 1) f[j][0] += f[j-1][0] * cnt[i];
	}
	return f[14][0] + f[14][1];
}
bool checks(int x, int y, int z){
	if(ch[x][1] == 'c') return 0;
	if(ch[x][1]!=ch[y][1] || ch[x][1]!=ch[z][1]) return 0;
	assert(ch[x][0]+1 == ch[y][0] && ch[y][0]+1 == ch[z][0]);
	return 1;
}
ll solve13(){
	static ll f[2][3][2][2], g[2][3][2][2];
	memset(f, 0, sizeof(f));
	memset(g, 0, sizeof(g));
	f[0][0][1][1] = 1;
	rep(i, 0, lim){
		memcpy(g, f, sizeof(g)); memset(f, 0, sizeof(f));
		rep(j, 0, 1) rep(k, 0, 2) rep(x, 0, 1) rep(y, 0, 1)
		if(g[j][k][x][y])
		{
			f[j][k][y][0] += g[j][k][x][y];
			if(!j && cnt[i]>1 && (!y || !(i % 9)))
				f[1][k][y][1] += g[j][k][x][y] * C[cnt[i]][2];
			if(!x && !y && k<2 && checks(i-2, i-1, i))
				f[j][k+1][1][1] += g[j][k][x][y] * C[cnt[i-2]][2] * C[cnt[i-1]][2] * C[cnt[i]][2];
		}
	}
	return f[1][2][0][0] + f[1][2][0][1] + f[1][2][1][0] + f[1][2][1][1];
}

unordered_map<int, bool> v;
int now[N];
int encode(int l, int r){
	int ret = 0;
	rep(i, l, r) ret = ret * 5 + now[i];
	return ret;
}
ll calc(int l, int r){
	ll ret = 1;
	rep(i, l, r) ret *= C[cnt[i]][now[i]];
	return ret;
}

ll dfs(int x, int y, int l, int r){
	if(!x && !y){
		int t = encode(l, r);
		if(v[t]) return 0;
		v[t] = 1; return calc(l, r);
	}
	ll ret = 0;
	if(x){
		rep(i, l, r) if(now[i] + 2 <= cnt[i])
			now[i] += 2, ret += dfs(x-1, y, l, r), now[i] -= 2;
		return ret;
	}
	rep(i, l, r) if(now[i] + 3 <= cnt[i])
		now[i] += 3, ret += dfs(x, y-1, l, r), now[i] -= 3;
	if(r < 27) rep(i, l+1, r-1) if(now[i-1]<cnt[i-1] && now[i]<cnt[i] && now[i+1]<cnt[i+1]) 
		now[i-1]++, now[i]++, now[i+1]++,
		ret += dfs(x, y-1, l, r),
		now[i-1]--, now[i]--, now[i+1]--;
	return ret;
}
ll solve3(){
	static ll a[4][2][5], f[2][5];
	memset(a, 0, sizeof(a));
	memset(f, 0, sizeof(f));
	rep(i, 0, 3) rep(j, 0, 1) rep(k, 0, 4)
		v.clear(), a[i][j][k] = dfs(j, k, i*9, i==3 ? lim : i*9+8);
	f[0][0] = 1;
	rep(i, 0, 3) per(j, 1, 0) per(k, 4, 0)
		rep(x, 0, j) rep(y, x?0:1, k) 
			f[j][k] += f[j-x][k-y] * a[i][x][y];
	return f[1][4];
}

void solve(){
	cin >> n;
	memset(cnt, 0, sizeof(cnt));
	rep(i, 1, n) {string s; cin >> s; cnt[id(s)]++;}
	ll ans = -solve13() + solve1() + solve2() + solve3();
	ll tmp = C[n][14], g = __gcd(ans, tmp);
	printf("%lld/%lld\n", ans / g, tmp / g);
}

int main(){
	init();
	int T; scanf("%d", &T); while(T--) solve();
	return 0;
}

詳細信息


Pretests


Final Tests

Test #1:

score: 10
Accepted
time: 1ms
memory: 4064kb

input:

10
20
4s 4p 3s 5s 1c 9p 2m 6s 2p 9m 8p 8m 7m 1p 6s 6m 5m 5p 4m 7p
17
1c 8m 3m 6s 1c 6c 6c 8m 3c 8p 7p 6c 4p 2m 5s 7p 7s
18
3p 6s 4s 3m 2p 7c 7p 7p 6s 2m 5c 8m 1p 2s 8s 3c 2c 4p
16
8p 2c 7m 4s 3p 7m 3s 3m 7s 2m 5c 4m 3c 5p 1m 1m
19
3c 6s 9m 7c 4c 8p 5s 3m 4c 1c 8m 1s 8p 4s 6s 8p 5s 3c 9m
18
2m 4m 7c ...

output:

1/38760
0/1
0/1
0/1
0/1
0/1
0/1
0/1
0/1
1/1

result:

ok 10 lines

Test #2:

score: 10
Accepted
time: 1ms
memory: 3804kb

input:

10
20
9m 3c 7c 5s 2p 9p 1s 9s 8p 6p 3s 6c 2p 1s 5p 2c 2m 2m 8p 9s
19
1p 6p 5s 6s 1c 2m 1p 8m 5s 4s 3c 2c 3p 3p 7c 7s 4c 6s 1m
22
7c 8m 5m 2m 7m 2p 5p 8m 1c 3s 6m 8p 5c 3p 5s 9s 7m 8s 9m 6s 4c 3p
25
3m 8m 9p 7p 4s 6p 4m 2p 2m 7m 2p 4c 6m 8s 7c 4s 7s 6s 4p 9m 7s 6p 5p 3p 5c
23
5m 7s 9m 8m 6c 5c 3p 7c ...

output:

0/1
0/1
0/1
1/44574
0/1
4/159885
0/1
0/1
0/1
0/1

result:

ok 10 lines

Test #3:

score: 10
Accepted
time: 1ms
memory: 3860kb

input:

10
23
7c 4c 7s 8p 3s 5c 1s 4m 4s 4s 5c 1p 7c 4p 8s 6p 7s 1p 1m 2m 6m 9p 2s
22
4c 7p 3m 6m 5m 3m 1m 5c 8m 9p 5c 1p 1p 5m 6s 3p 8m 7p 1c 2c 4p 5m
25
7s 2m 1m 3p 9s 5s 8p 4s 4s 4m 8s 2p 8m 5m 1c 1m 9p 2s 1s 1p 3m 2c 2c 4c 8s
20
9p 6c 1p 3c 6p 8p 3s 5m 4s 1c 1s 3s 4m 2m 2s 6p 8p 2c 4s 7p
22
5p 5s 4m 6m ...

output:

0/1
0/1
0/1
0/1
1/319770
0/1
0/1
0/1
0/1
0/1

result:

ok 10 lines

Test #4:

score: 10
Accepted
time: 1ms
memory: 4068kb

input:

10
19
6m 3c 8p 5s 1m 8m 7c 1m 3s 6p 1s 5c 9m 4p 7p 4p 2p 3c 6s
24
7s 6m 4m 8s 3s 1s 1s 2m 1m 5m 5p 6s 4c 5m 3m 7p 1c 4c 7s 4s 2m 8p 9p 5p
25
8m 1s 3c 4m 4m 6p 8p 2p 8p 9m 9p 3p 1p 9s 6s 4c 4p 5p 7m 7p 4p 7s 6c 2m 6p
25
6s 2p 3p 5m 4s 7m 9p 8s 4p 9m 7s 3c 1m 5p 2c 2s 8p 7p 3s 3m 2m 7p 4c 5m 4p
20
3c ...

output:

0/1
1/81719
3/742900
3/371450
0/1
0/1
0/1
0/1
0/1
0/1

result:

ok 10 lines

Test #5:

score: 10
Accepted
time: 73ms
memory: 4476kb

input:

10
109
5c 3p 4c 8s 3s 6s 7s 1s 3c 7p 4p 6s 3s 5s 1c 5s 7m 3c 6c 3m 9p 7c 9p 7c 3s 2c 4m 2s 1c 1m 6m 1m 2s 1s 1p 2p 7c 4s 3p 9m 2m 8p 5c 8p 1p 3p 5m 4m 6c 7s 3m 2p 4s 8p 6m 6p 6s 7p 9s 7m 6c 4s 4c 3c 4p 3c 8m 7p 8m 7s 3m 3s 2c 9m 8m 2c 3m 9p 6m 1s 8s 6s 7m 1m 6c 4p 5m 8m 2s 8s 2m 1p 7s 5p 5c 5p 2p 1p...

output:

438517325999/160330885263858960
5519303885/1767477707092944
315803459/210200461893180
1113059528533/404822104630406520
100726669633/44186942677323600
1800166337/584725152763800
247005179741/91748617512913200
40299842873/12428282928826440
118862116391/59458448728028700
2580573199/868119825121065

result:

ok 10 lines

Test #6:

score: 10
Accepted
time: 100ms
memory: 4196kb

input:

10
103
1c 3p 6m 1s 2m 7m 1c 9s 2s 3c 6p 7m 3c 9s 5p 1p 8p 1s 4c 8s 1m 1p 7s 6p 3c 2c 8m 3p 4s 3m 7p 6p 7p 1c 2s 8m 7s 7c 5p 1m 2p 6c 7m 5c 7p 4c 2s 6c 3m 3m 5s 9p 9s 1s 4p 7m 6s 3s 7s 9m 8p 4c 1m 8m 8s 8p 5s 6s 4p 3m 3s 7c 6c 8s 5c 2p 7c 4s 5m 4m 9p 7s 3p 4c 6c 5m 7p 9m 7c 8m 1s 2c 9s 5m 1p 5c 3s 6s...

output:

4357204237/2023866562784850
923931927481/347808183330273600
57714372151/17427686431277403
300638747/144154304891880
120055658171/38320539030548190
300343959787/118654754805463980
412046647693/189250121876392170
517695872597/137118194912492700
18873223157/5997113535284730
316898500244/83676706780057695

result:

ok 10 lines

Test #7:

score: 10
Accepted
time: 156ms
memory: 4216kb

input:

10
133
1s 1s 7p 4s 1p 9s 7m 3p 6s 8s 2s 9p 3s 7s 8s 2m 4p 6m 7c 9s 7m 1c 6p 5p 5m 5p 1c 3p 1m 3s 9s 5c 2m 5s 9s 4p 4m 6c 6s 3s 3m 5s 8s 6m 2c 6p 4p 5p 6c 8m 4c 4p 8p 7c 1s 9p 1p 2c 4c 9m 1m 5c 2m 7c 8p 3p 2p 2s 4m 1m 1p 7p 8m 3c 2p 6m 1m 6s 9m 7m 5m 6p 7m 5m 1c 3m 3p 7p 3c 5s 8s 1c 7s 2s 2p 2m 4m 9m...

output:

49330101751/15939248518584875
544160045501/192992682900247428
4944118051151/1708687441192298600
14272852777/4980266365168215
244079458745/104349775513954302
1178845800113/347808183330273600
409704617233/124463414269524000
790856287777/260874438784885755
16282623809/5848263118189316
2143179701279/708...

result:

ok 10 lines

Test #8:

score: 10
Accepted
time: 165ms
memory: 4160kb

input:

10
126
5p 5c 3c 1p 3m 8m 4p 5p 3s 7p 3s 5p 6p 7p 4p 4s 3p 8p 8m 2m 1p 4m 1c 2s 9p 5c 4m 1s 8p 6s 9s 6c 5p 3s 7c 1m 4s 5c 7p 7c 5s 5m 2m 6s 7m 4s 8s 9m 2p 7m 5s 3c 9m 4p 4c 2s 9p 4p 6m 2s 3p 6m 1p 3m 5m 2c 2p 1s 1p 8p 3s 4c 1s 6s 6p 9m 9m 1c 4s 8s 9p 4m 7c 6c 5m 6s 7m 1m 2m 3p 1m 6c 3m 7s 1c 5s 9s 8s...

output:

1769364720488/459365261817235125
132486320564/47520544325920875
95007114903/33735175385867210
3834820426178/1378095785451705375
4207030689371/1378095785451705375
1995823601647/684548778482382000
10045994464373/3060335715568296000
3901375737747/1223890240316986000
145058089283/63083373958797390
49271...

result:

ok 10 lines

Test #9:

score: 10
Accepted
time: 170ms
memory: 4212kb

input:

10
125
4m 6s 3c 5m 1p 3s 1c 8s 1s 4c 5m 9s 8s 1s 3s 1m 6m 3m 9m 5s 1p 9p 6c 7m 3c 2p 3p 6c 2m 2m 2c 8p 3p 6p 9s 7s 1s 4m 7m 7p 2s 5s 3m 4s 5c 9s 3s 6c 2c 9m 7s 4p 5m 6s 1m 7p 6p 2p 3s 5p 2p 7m 6p 8p 2c 8s 5s 7p 6c 2s 8m 1s 8s 4s 6s 6s 2c 8p 8m 5p 1p 3c 3c 5c 3p 4p 1p 7m 5s 8p 6m 1c 2p 5c 6p 4p 5p 7s...

output:

3994538145151/1224974031512627000
164912958069/72057295971331000
4513127238533/1378095785451705375
36762818149/12709245430355940
5058554068093/1708687441192298600
8187159059951/2447780480633972000
105676567673/30597256007924650
1511235978388/516277772130874875
172118211457/55123831418068215
96726780...

result:

ok 10 lines

Test #10:

score: 10
Accepted
time: 203ms
memory: 4484kb

input:

10
136
7s 2p 1s 8m 9m 2c 9s 6p 7s 9s 4p 3p 4m 4p 7p 5p 4p 2c 3s 4m 1m 9p 4c 6c 2m 8s 3s 6s 6m 5m 1p 5s 8m 9p 2m 6p 6m 3s 1m 8s 4c 4m 7c 3c 3m 2p 5m 3p 1s 8p 6p 6m 2p 6s 7m 2p 3c 5s 3m 2s 6c 9m 8s 7c 2s 4p 8m 1s 6c 3m 2c 1p 1s 7c 5p 9m 3p 7s 4s 3m 9s 7p 9p 5m 6c 4s 5c 6s 1m 6m 1c 7m 8p 9s 1p 2m 3s 7s...

output:

2143179701279/708384171528036000
98667734899/31773113575889850
2268378791823/683474976476919440
1427183516417/476596703638347750
2143179701279/708384171528036000
1369334608447/423641514345198000
1427183516417/476596703638347750
98667734899/31773113575889850
2143179701279/708384171528036000
214317970...

result:

ok 10 lines