【LOJ】#6434. 「PKUSC2018」主斗地
题解
什么,我这题竟然快到了LOJ rk1????
搜起来有点麻烦,不过感觉还是比斗地主好下手(至今没敢写斗地主
首先是暴力搜牌型,最多\(3^{16}\)(什么判解还要复杂度怂成一团)的样子??
然后判牌型,显然只要考虑单牌,和3 + x,4+2
然后暴力搜网友的3和4
暴力搜jry的3和4
然后枚举3搭配了几个2,
然后jry从大到小开始去除大小为2的对子,网友从小到大,是个简单的贪心
之后看看可以去掉的单牌的个数,也是jry从大到小,网友从小到大
之后的就是单牌互相压看看合不合法就好了
代码
#include <bits/stdc++.h>
#define fi first
#define se second
#define pii pair<int,int>
#define pdi pair<db,int>
#define mp make_pair
#define pb push_back
#define enter putchar('\n')
#define space putchar(' ')
#define eps 1e-8
#define mo 974711
#define MAXN 100005
//#define ivorysi
using namespace std;
typedef long long int64;
typedef double db;
template<class T>
void read(T &res) {
res = 0;char c = getchar();T f = 1;
while(c < '0' || c > '9') {
if(c == '-') f = -1;
c = getchar();
}
while(c >= '0' && c <= '9') {
res = res * 10 + c - '0';
c = getchar();
}
res *= f;
}
template<class T>
void out(T x) {
if(x < 0) {x = -x;putchar('-');}
if(x >= 10) {
out(x / 10);
}
putchar('0' + x % 10);
}
char s[20];
int rem[16],A[16],W[16],K[16],ans,jry[16];
int C[16],D[16],H[16],J[16],P[16];
int code(char c) {
if(c >= '4' && c <= '9') return c - '4' + 1;
if(c == 'T') return 7;
if(c == 'J') return 8;
if(c == 'Q') return 9;
if(c == 'K') return 10;
if(c == 'A') return 11;
if(c == '2') return 12;
if(c == 'w') return 13;
if(c == 'W') return 14;
}
bool check(int f,int t) {
for(int i = 0 ; i <= t ; ++i) {
memcpy(H,W,sizeof(H));
memcpy(J,K,sizeof(K));
if(2 * i + t - i + f * 2 + f * 4 + t * 3 > 17) break;
int cnt = 0;
for(int j = 1 ; j <= 14 ; ++j) {
if(H[j] >= 2 && cnt < i) {H[j] -= 2;++cnt;}
if(H[j] >= 2 && cnt < i) {H[j] -= 2;++cnt;}
if(cnt == i) break;
}
if(cnt < i) break;
cnt = 0;
for(int j = 14 ; j >= 1 ; --j) {
if(J[j] >= 2 && cnt < i) {J[j] -= 2;++cnt;}
if(J[j] >= 2 && cnt < i) {J[j] -= 2;++cnt;}
if(cnt == i) break;
}
if(cnt < i) break;
memset(P,0,sizeof(P));
cnt = 2 * f + t - i;
for(int j = 14 ; j >= 1 ; --j) {
int t = min(cnt,J[j]);
J[j] -= t;cnt -= t;
if(cnt == 0) break;
}
if(cnt) continue;
cnt = 2 * f + t - i;
for(int j = 1 ; j <= 14 ; ++j) {
int t = min(cnt,H[j]);
H[j] -= t;cnt -= t;
if(cnt == 0) break;
}
if(J[14]) continue;
for(int j = 1 ; j <= 14 ; ++j) {
P[j] += H[j];
P[j + 1] -= J[j];
}
cnt = 0;
for(int j = 1 ; j <= 14 ; ++j) {
cnt += P[j];
if(cnt > 0) break;
}
if(cnt == 0) return true;
}
return false;
}
bool brute_jry(int dep,int four,int three,int f,int t,int q1,int q2) {
if(four == f && t == three) return check(four,three);
if(dep >= 12) return false;
q1 += C[dep];q2 += D[dep];
if(q1 > 0 || q2 > 0) return false;
if(K[dep] >= 3) {
K[dep] -= 3;
if(brute_jry(dep + 1,four,three,f,t + 1,q1 - 1,q2)) return true;
K[dep] += 3;
}
if(K[dep] >= 4) {
K[dep] -= 4;
if(brute_jry(dep + 1,four,three,f + 1,t,q1,q2 - 1)) return true;
K[dep] += 4;
}
return brute_jry(dep + 1,four,three,f,t,q1,q2);
}
bool brute_wangyou(int dep,int four,int three) {
if(four * 6 + three * 4 > 17) return false;
if(dep > 12) {
if(brute_jry(1,four,three,0,0,0,0)) return true;
return false;
}
if(W[dep] >= 3) {
W[dep] -= 3;++C[dep];
if(brute_wangyou(dep + 1,four,three + 1)) return true;
W[dep] += 3;--C[dep];
}
if(W[dep] >= 4) {
W[dep] -= 4;++D[dep];
if(brute_wangyou(dep + 1,four + 1,three)) return true;
W[dep] += 4;--D[dep];
}
if(brute_wangyou(dep + 1,four,three)) return true;
return false;
}
void dfs(int dep,int r) {
if(!r) {
memset(C,0,sizeof(C));
memset(D,0,sizeof(D));
memcpy(W,A,sizeof(A));
memcpy(K,jry,sizeof(jry));
if(brute_wangyou(2,0,0)) {++ans;}
return;
}
if(dep > 14) return;
for(int i = 0 ; i <= rem[dep] ; ++i) {
if(i > r) break;
jry[dep] = i;
dfs(dep + 1,r - i);
jry[dep] = 0;
}
}
int main() {
#ifdef ivorysi
freopen("f1.in","r",stdin);
#endif
while(scanf("%s",s + 1) != EOF) {
memset(A,0,sizeof(A));
for(int i = 1 ; i <= 12 ; ++i) rem[i] = 4;
rem[13] = rem[14] = 1;
ans = 0;
for(int i = 1 ; i <= 17 ; ++i) {
A[code(s[i])]++;rem[code(s[i])]--;
}
dfs(1,17);
out(ans);enter;
}
}
【LOJ】#6434. 「PKUSC2018」主斗地的更多相关文章
- Loj#6434「PKUSC2018」主斗地(搜索)
题面 Loj 题解 细节比较多的搜索题. 首先现将牌型暴力枚举出来,大概是\(3^{16}\)吧. 然后再看能打什么,简化后无非就三种决策:单牌,\(3+x\)和\(4+x\). 枚举网友打了几张\( ...
- 「PKUSC2018」主斗地(暴搜)
这道斗地主比 \(PKUWC\) 那道可做多了... 我们用 \(NOIP\) 那道斗地主的思路:暴搜出三代和四代,贪心出散牌. 还有jry为什么要出xx网友而不出他的另一个老婆 我们发现两个人的每回 ...
- LOJ #6436. 「PKUSC2018」神仙的游戏(字符串+NTT)
题面 LOJ #6436. 「PKUSC2018」神仙的游戏 题解 参考 yyb 的口中的长郡最强选手 租酥雨大佬的博客 ... 一开始以为 通配符匹配 就是类似于 BZOJ 4259: 残缺的字符串 ...
- LOJ #6435. 「PKUSC2018」星际穿越(倍增)
题面 LOJ#6435. 「PKUSC2018」星际穿越 题解 参考了 这位大佬的博客 这道题好恶心啊qwq~~ 首先一定要认真阅读题目 !! 注意 \(l_i<r_i<x_i\) 这个条 ...
- LOJ #6432. 「PKUSC2018」真实排名(组合数)
题面 LOJ #6432. 「PKUSC2018」真实排名 注意排名的定义 , 分数不小于他的选手数量 !!! 题解 有点坑的细节题 ... 思路很简单 , 把每个数分两种情况讨论一下了 . 假设它为 ...
- Loj#6433「PKUSC2018」最大前缀和(状态压缩DP)
题面 Loj 题解 先转化题意,其实这题在乘了\(n!\)以后就变成了全排列中的最大前缀和的和(有点拗口).\(n\leq20\),考虑状压\(DP\) 考虑一个最大前缀和\(\sum\limits_ ...
- Loj#6432「PKUSC2018」真实排名(二分查找+组合数)
题面 Loj 题解 普通的暴力是直接枚举改或者不改,最后在判断最后对哪些点有贡献. 而这种方法是很难优化的.所以考虑在排序之后线性处理.首先先假设没有重复的元素 struct Node { int p ...
- Loj 6433. 「PKUSC2018」最大前缀和 (状压dp)
题面 Loj 题解 感觉挺难的啊- 状压\(dp\) 首先,有一个性质 对于一个序列的最大前缀和\(\sum_{i=1}^{p} A[i]\) 显然对于每个\(\sum_{i=p+1}^{x}A[i] ...
- Loj 6432. 「PKUSC2018」真实排名 (组合数)
题面 Loj 题解 枚举每一个点 分两种情况 翻倍or不翻倍 \(1.\)如果这个点\(i\)翻倍, 要保持排名不变,哪些必须翻倍,哪些可以翻倍? 必须翻倍: \(a[i] \leq a[x] < ...
随机推荐
- MT【81】含参数三次函数因式分解
解答: 评:这题实质上是对关于$x$的三次函数进行了一个因式分解.这种把$a$看成主元的技巧是初中处理高次的因式分解的常用技巧.如果用三次求导去做计算量比较大,要计算极值.
- KUR-Couriers
题目链接: QwQ Solution: 以权值为下标,对每个点建树 对于x点,以它为根的树涵盖的是1到x区间内每个数出现的次数 Code: #include<bits/stdc++.h> ...
- noip2017颓废记
作为一个从初中就开始学信息的蒟蒻,自然要去提高组了~~~ 比赛前day1 跟平常一样在机房颓废着,上午在洛谷看到了站长大人的忠告后,看了看模板题,发现没几个会打的(正常). 下午想一想发现自己的dp垃 ...
- 【bzoj1088】扫雷
见过水的,没见过这么水的 Description 相信大家都玩过扫雷的游戏.那是在一个n*m的矩阵里面有一些雷,要你根据一些信息找出雷来.万圣节到了,“余”人国流行起了一种简单的扫雷游戏,这个游戏规则 ...
- BZOJ4912 [Sdoi2017]天才黑客 【虚树 + 最短路】
题目链接 BZOJ4912 题解 转移的代价是存在于边和边之间的 所以把边看做点,跑最短路 但是这样做需要把同一个点的所有入边和所有出边之间连边 \(O(m^2)\)的连边无法接受 需要优化建图 膜一 ...
- 消除JQuery Mobile 列表样式右侧箭头
有时候我们看到JQM上面有一些呈现跟我们要的很像如下面这个Listview效果 程序代码如下: view sourceprint? 1.<ul data-role="listvie ...
- 「Django」contenttypes基本用法
当一张表和多个表ForeignKey关联,并且多个FK中只能选择其中一个或其中n个时,可以利用contenttypes,只需定义三个字段就搞定! contenttypes 是Django内置的一个应用 ...
- 基于docker的spark-hadoop分布式集群之一: 环境搭建
一.软件准备 1.基础docker镜像:ubuntu,目前最新的版本是18 2.需准备的环境软件包: (1) spark-2.3.0-bin-hadoop2.7.tgz (2) hadoop-2.7. ...
- AngularJS入门基础——表达式
表达式在AngularJS应用中广泛的使用,因此深入理解AngularJS如何使用并运算表达式是非常重要的. 表达式和eval非常相似,但是由于表达式由AngularJS来处理,它们有已下显著不同 ...
- mac 无法验证副本
转: 这个是拆机后断了电源,导致时间不对,也就是说现在电脑的时间比U盘制作的时间还早,所以有这样的错误提示. 在终端里面修改时间请参考下面的代码,按回车键确认:date 062614102014.30 ...