[GXOI/GZOI2019]宝牌一大堆(dp)
这个麻将题还算挺友善的,比隔壁zjoi的要好得多。。。
比较正常的做法是五维dp
但事实上六维dp也是完全不会被卡的
七对子选权值最高的七个,国士无双直接$13^2$暴力
$dp[i][j][0/1][k][l][m]$表示枚举到了第i张牌,已经凑了j个面子,有无雀头,第i张牌已经用了k张,第i+1张牌用了l张,第i+2张牌用了m张,直接暴力转移。。。
然后你会得到50...
当然需要优化。
优化1:
枚举到dp值为0的直接continue,这样的不合法牌型有很多可以直接跳过。
优化2:
l和m只枚举到2,原因?如果枚举到三个顺子的话那么我们完全可以用三个刻子等效替代。
优化3:
不需要考虑杠。
原因?
$C_{4}^{3}=4$,$C_{4}^{4}=1$
就算这张牌是宝牌选刻子也必然优于杠子
代码就领略一下精神吧(
#include<cstdio> #include<algorithm> #include<queue> #define d01(x) for(int x=0;x<2;x++) using std::priority_queue; using std::max; typedef long long lint; ]; void dm(lint &kk,lint l){kk=max(kk,l);} ],dora[];//1~9,10~18,19~27,28,29,30,31,32,33,34 lint dp[][][][][][]; lint dg[]; lint ans; ][]={ ,,,,, ,,,,, ,,,,, ,,,,, ,,,, }; ]={,,,,,,,,,,,,,}; ]={,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,}; ]={,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,}; void kokushi() { int x; ;i<=;i++) { x=yaoku[i]; lint tmp=; tmp*=c[a[x]][]*dora[x]*dora[x]; ;j<=;j++) { if(i==j) continue;x=yaoku[j]; tmp*=a[x]*dora[x]; } ans=max(ans,tmp); } } priority_queue<int> q; void chitoi() { lint tmp=; ;i<=;i++) q.push(c[a[i]][]*dora[i]*dora[i]); int g; ;i<=;i++) { g=q.top(); q.pop(); tmp*=g; } ans=max(ans,tmp); while(!q.empty()) q.pop(); } void clr() { ;i<=;i++) { dg[i]=; ;j<=;j++) { ;k<=;k++) { ;l<=;l++) { ;m<=;m++) dp[i][j][][k][l][m]=dp[i][j][][k][l][m]=; } } } } ;i<=;i++) a[i]=,dora[i]=; ans=; dp[][][][][][]=; } int main() { int T; scanf("%d",&T); while(T--) { clr(); ) { scanf("%s",si); ]==') break; ]==]-']--; ]==]-]--; ]==]-]--; ]==]--; ]==]--; ]==]--; ]==]--; ]==]--; ]==]--; ]==]--; } ) { scanf("%s",si); ]==') break; ]==]-; ]==]-]=; ]==]-]=; ]==]=; ]==]=; ]==]=; ]==]=; ]==]=; ]==]=; ]==]=; } kokushi();//国士无双 chitoi();//七对子 ;i<=;i++) { ;j<=;j++) { ;k<=;k++) { ;l<=;l++) { ;m<=;m++) { ][k][l][m]&&!dp[i][j][][k][l][m]) continue; ) dm(dp[i][j][][k+][l][m],dp[i][j][][k][l][m]/c[a[i]][k]*c[a[i]][k+]*dora[i]*dora[i]); //雀头 ) { ) d01(o) dm(dp[i][j+][o][k+][l][m],dp[i][j][o][k][l][m]/c[a[i]][k]*c[a[i]][k+]*dora[i]*dora[i]*dora[i]); //刻子 &&a[i+]-l>&&a[i+]-m>&&l!=&&m!=) d01(o) dm(dp[i][j+][o][k+][l+][m+],dp[i][j][o][k][l][m]/c[a[i]][k]*c[a[i]][k+]*dora[i]/c[a[i+]][l]*c[a[i+]][l+]*dora[i+]/c[a[i+]][m]*c[a[i+]][m+]*dora[i+]); //顺子 } dm(dp[i+][j][][l][m][],dp[i][j][][k][l][m]); dm(dp[i+][j][][l][m][],dp[i][j][][k][l][m]); //转移 ) dg[i]=max(dg[i],dp[i][j][][k][l][m]); } } } } } ;i<=;i++) ans=max(ans,dg[i]); printf("%lld\n",ans); } ; }
Orz
[GXOI/GZOI2019]宝牌一大堆(dp)的更多相关文章
- [LOJ3084][GXOI/GZOI2019]宝牌一大堆——DP
题目链接: [GXOI/GZOI2019]宝牌一大堆 求最大值容易想到$DP$,但如果将$7$种和牌都考虑进来的话,$DP$状态不好设,我们将比较特殊的七小对和国士无双单独求,其他的进行$DP$. 观 ...
- P5301 [GXOI/GZOI2019]宝牌一大堆
题目地址:P5301 [GXOI/GZOI2019]宝牌一大堆 这里是官方题解(by lydrainbowcat) 部分分 直接搜索可以得到暴力分,因为所有和牌方案一共只有一千万左右,稍微优化一下数据 ...
- 【BZOJ5503】[GXOI/GZOI2019]宝牌一大堆(动态规划)
[BZOJ5503][GXOI/GZOI2019]宝牌一大堆(动态规划) 题面 BZOJ 洛谷 题解 首先特殊牌型直接特判. 然后剩下的部分可以直接\(dp\),直接把所有可以存的全部带进去大力\(d ...
- luogu P5301 [GXOI/GZOI2019]宝牌一大堆
传送门 wdnm又是打麻将 首先国土无双可以直接枚举哪种牌用了\(2\)次算贡献,然后\(7\)个对子可以把每种牌的对子贡献排序,取最大的\(7\)个,剩下的牌直接暴力枚举是不行的,考虑dp,设\(f ...
- 题解 P5301 【[GXOI/GZOI2019]宝牌一大堆】
这道题除了非常恶心以外也没有什么非常让人恶心的地方 当然一定要说有的话还是有的,就是这题和咱 ZJOI 的 mahjong 真的是好像的说~ 于是就想说这道题出题人应该被 锕 掉 noteskey 整 ...
- [GXOI/GZOI2019]宝牌一大堆
感觉比ZJOI的麻将要休闲很多啊. 这个题就是一个最优化问题,没有面子的特殊牌型可以直接用复杂度较低的贪心判掉. 有面子的话就是一个经典dp.(曾经还在ZJOI写过这个毒瘤东西 大概就是存一下对子,面 ...
- [luogu 5301][bzoj 5503] [GXOI/GZOI2019] 宝牌一大堆
题面 好像ZJOI也考了一道麻将, 这是要发扬中华民族的赌博传统吗??? 暴搜都不会打, 看到题目就自闭了, 考完出来之后看题解, \(dp\), 可惜自己想不出来... 对于国士无双(脑子中闪过了韩 ...
- 【题解】Luogu P5301 [GXOI/GZOI2019]宝牌一大堆
原题传送门 首先先要学会麻将,然后会发现就是一个暴力dp,分三种情况考虑: 1.非七对子国士无双,设\(dp_{i,j,k,a,b}\)表示看到了第\(i\)种牌,一共有\(j\)个\(i-1\)开头 ...
- [GX/GZOI2019]宝牌一大堆(DP)
出这种麻将题有意思吗? 乍看很难实则很水,就是麻将式DP,想必大家很熟悉了吧.首先把“国士无双”和“七对子”两种牌型判掉,然后观察牌胡的形式,发现每多一张牌实际上就是把1个面子变成1个杠子,然后可以直 ...
随机推荐
- Velocity魔法堂系列一:入门示例(转)
Velocity魔法堂系列一:入门示例 一.前言 Velocity作为历史悠久的模板引擎不单单可以替代JSP作为Java Web的服务端网页模板引擎,而且可以作为普通文本的模板引擎来增强服务端程序文本 ...
- Silverlight 后台利用代码触发 Button 的Click事件
页面上一个查询按钮,当用户点击 回车键 的时候 处罚查询按钮的onclick事件 public MainPage() { InitializeComponent(); this.KeyDown += ...
- ubuntu 12.04 alt+tab无法切换窗口的问题(转载)
转自:http://www.2cto.com/os/201209/153282.html ubuntu 12.04 alt+tab无法切换窗口的问题 安装cpmpiz配置管理程序. sudo ...
- E20180225-hm-xa
variation n. 变化,变动; 变异,演变; 变奏曲; 变量; auxiliary adj. 辅助的 subscript adj. 下标的,写在下方的,脚注的; n. 下标,脚注,下角数 ...
- Uix Kit 快速建站前端开发套件-工具箱
这个产品维护已经有一年了(由于业务需求不同,目前没有做中文版,产品本身是针对国外网站),自己本身是做UI出生,开发只是业余爱好,仅仅作为平时工作的需要.杂七杂八会一些前后端开发.并非职业码农! 我是一 ...
- 贪心 Codeforces Round #273 (Div. 2) C. Table Decorations
题目传送门 /* 贪心:排序后,当a[3] > 2 * (a[1] + a[2]), 可以最多的2个,其他的都是1个,ggr,ggb, ggr... ans = a[1] + a[2]; 或先2 ...
- 题解报告:hdu 1236 排名
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1236 Problem Description 今天的上机考试虽然有实时的Ranklist,但上面的排名 ...
- LD_LIBRARY_PATH与-L的关系以及延伸
最近跟同学讨论c++在编译时g++ -L.. 和LD_LIBRARY_PATH的问题,今天在做一个东西的时候发现,我对这两个东西的理解是错误的,经过一番研究,写下我对这些东西的想法,如果有不对的地方, ...
- sdut1650I-Keyboard(dp)
链接 题目大意就相当于 跟你一串字符串 让你截成k段 使总体的值最小 想法是递归的 递归太慢 可以转换为递推的 这样就有可以推出状态方程 dp[i][j] = max(dp[i][j],dp[i-1] ...
- Sql Server把本地数据库传到服务器数据库
上一篇文章我们已经把网站布署到服务器中了,如果是动态网站肯定是有数据库的,接下来通过Sql Server把本地数据库上传到服务器数据库中. 打开Sql Server连接本地数据库,选中要导出的数据库, ...