P2540 斗地主增强版
参考大佬题解
思路:顺子暴力搜,剩下的牌我不会贪心所以用记忆化搜索(或者dp);
注意:双王不能当对,二不算顺子
代码
#include <cstdio>
#include <iostream>
#include <cstring>
#include <cctype>
#include <algorithm>
using namespace std; #define res register int
#define inf 0x3f3f3f3f
inline int read() {
int x(),f(); char ch;
while(!isdigit(ch=getchar())) if(ch=='-') f=-;
while(isdigit(ch)) x=(x<<)+(x<<)+ch-'',ch=getchar();
return x*f;
} int n,T,ans;
int a[];
int f[][][][];
//单个牌的数目,双,三,四,王
int c[]; template <typename T>
inline T my_max(T a,T b) {return a<b?a:b;}
template <typename T>
inline T my_min(T a,T b) {return a<b?a:b;} int calc(int a,int b,int c,int d)
{
if(a< || b< || c< || d<) return inf;
if(!c && !d) return a+b;
if(~f[a][b][c][d]) return f[a][b][c][d];
//拆四
int tmp=my_min(calc(a+,b,c+,d-),calc(a+,b+,c,d-));
//拆三
tmp=my_min(tmp,my_min(calc(a+,b+,c-,d),calc(a+,b,c-,d)));
//四带一
tmp=my_min(tmp,my_min(calc(a-,b,c,d-),calc(a,b-,c,d-))+);
//四带二
tmp=my_min(tmp,my_min(calc(a,b-,c,d-),calc(a,b,c,d-))+);
//三带一
tmp=my_min(tmp,my_min(calc(a-,b,c-,d),calc(a,b-,c-,d))+);
return f[a][b][c][d]=tmp;
}
void dfs(int x)
{
if(x>=ans) return ;
bool f=true;
int cnt;
//暴力出顺子
for(res k= ; k<= ; k++)
for(res i= ; i<= ; i++)
{
f=true;
if(k==) cnt=;
else if(k==) cnt=;
else cnt=;
while(f&&i+cnt-<=)
{
for(res j= ; j<=cnt ; j++)
if(a[i+j-]<k) {
f=false; break;
}
if(!f) continue;
for(res j= ; j<=cnt ; j++)
a[i+j-]-=k;
dfs(x+);
for(res j= ; j<=cnt ; j++)
a[i+j-]+=k;
cnt++;//看有没有更长的顺子
}
}
c[]=c[]=c[]=c[]=;
for(res i= ; i<= ; i++) c[a[i]]++;
if(a[]==) ans=my_min(ans,x+calc(c[],c[],c[],c[])+);
//王炸
ans=my_min(ans,x+calc(a[]+c[],c[],c[],c[]));
} int main()
{
T=read(); n=read();
memset(f,-,sizeof(f));
while(T--)
{
memset(a,,sizeof(a));
ans=n;
for(res i= ; i<=n ; i++)
{
int x=read(),y=read();
if(x==) a[]++;
else if(x>=) a[x]++;
else if(x==) a[]++;
else if(x==) a[]++;
}
dfs();
printf("%d\n",ans);
} return ;
}
P2540 斗地主增强版的更多相关文章
- Luogu 2540 斗地主增强版(搜索,动态规划)
Luogu 2540 斗地主增强版(搜索,动态规划) Description 牛牛最近迷上了一种叫斗地主的扑克游戏.斗地主是一种使用黑桃.红心.梅花.方片的A到K加上大小王的共54张牌来进行的扑克牌游 ...
- 洛谷 题解 P2540 【斗地主增强版】
[分析] 暴力搜顺子,贪心出散牌 为什么顺子要暴力? 玩过斗地主的都知道,并不是出越长的顺子越好,如果你有一组手牌,3,4,5,6,7,6,7,8,9,10,你一下把最长的出了去,你会单两张牌,不如出 ...
- [Luogu2540][NOIP2016]斗地主增强版(搜索+DP)
增强版就是原版中两鬼不算对子的版本. 先爆搜出完所有对子,剩下的牌DP处理. 考虑每个数码的拆牌情况,最多可能被拆成5种情况:1+1+1+1,1+1+2,1+3,2+2,4.故DP状态数最多为5^13 ...
- luogu2540 斗地主增强版
题目大意 给你一副手牌,没有飞机带翅膀,按斗地主的规则,求将所有牌打出的最少次数. 题解 先不考虑顺子 我们已经知道花色对牌没有影响,那么如果不考虑顺子,每个牌具体是什么数字我们也用不着知道,我们关心 ...
- Luogu2540 斗地主增强版(搜索+动态规划)
单纯的暴搜似乎还是很好写的,然而过不了.出完顺子之后答案是可以dp出来的,于是大力搜然后大力dp就好了. dp时强行讨论完了几乎所有拆牌情况,理性愉悦一发. #include<iostream& ...
- 【NOIP2015】斗地主 D1 T3 及 增强版 (送命题)
恶心送命模拟题 暴搜顺子,DP预处理剩下的. 由于官方数据太水,很多情况没有讨论的都能过普通版本,想要测试自己代码正确性的同学们可以交交这道题,有很多dalao给出了hack数据 : Luogu P2 ...
- 将表里的数据批量生成INSERT语句的存储过程 增强版
将表里的数据批量生成INSERT语句的存储过程 增强版 有时候,我们需要将某个表里的数据全部或者根据查询条件导出来,迁移到另一个相同结构的库中 目前SQL Server里面是没有相关的工具根据查询条件 ...
- 最新GHOST XP系统下载旗舰增强版 V2016年
系统来自:系统妈:http://www.xitongma.com 深度技术GHOST xp系统旗舰增强版 V2016年3月 系统概述 深度技术ghost xp系统旗舰增强版集合微软JAVA虚拟机IE插 ...
- 最新深度技术GHOST XP系统旗舰增强版 V2016年
来自系统妈:http://www.xitongma.com 深度技术GHOST xp系统旗舰增强版 V2016年 系统概述 深度技术ghost xp系统旗舰增强版集合微软JAVA虚拟机IE插件,增强浏 ...
随机推荐
- 301. Remove Invalid Parentheses去除不符合匹配规则的括号
[抄题]: Remove the minimum number of invalid parentheses in order to make the input string valid. Retu ...
- Windows Server 2012 R2 Standard x64 deploy Visual Studio 2015 Application
When I run the Server application on Windows Server 2012 R2 operation system. I meet the error:MSVCP ...
- BS4爬虫实例应用-CISP
爬取目前在官网可查询的CISP证书编号以及有效期并入库 也算是暴力破解,burp使用grep功能呢也可以实现. 下面是python的代码 #coding=utf-8 import requests i ...
- Web测试-day
昨天太忙忘了写博客,今天补上: 这两天完成的工作: 我们组选定了博客园和CSDN作为对比,进行Web测试. 胡俊辉--找到了10个网页的bug,并完成了bug记录文档,并且对CSDN和博客园进行功能分 ...
- Jrebel 独立部署tomcat 远程同步项目
一直在用 jrebel 感觉热部署的 功能,修改xml配置文件等,省去了很多的重新启动的时间. 由于偶然间发现 jrebel 还有remote 路由功能.这样,在服务器端用jrebel部署的项目和本地 ...
- ConfigureAwait(false)避免上下文延续
之前MVC利用MvcHtmlString封装通用下拉菜单,菜单数据需要从webapi获取,自然用到了 await Http Client.GetAsync(Url)方法,前端 @Html.Select ...
- 查看ubuntu 14.04的网关和DNS
root@ubuntu:~# nm-tool NetworkManager Tool State: connected (global) - Device: eth0 [自动以太网] -------- ...
- HDU 6127 Hard challenge (极角扫描)
题意:给定 n 个点,和权值,他们两两相连,每条边的权值就是他们两个点权值的乘积,任意两点之间的直线不经过原点,让你从原点划一条直线,使得经过的直线的权值和最大. 析:直接进行极角扫描,从水平,然后旋 ...
- redis整理の主从复制
redis 主从复制配置和使用都非常简单.通过主从复制可以允许多个 slave server 拥有和 master server 相同的数据库副本. 特点: (1).master 可以拥有多个 sla ...
- RabbitMQ与.net core(三) fanout类型Exchange 与 消息的过期时间 与 队列的存活时间
上一篇我们讲了关于direct类型的Exchange,这一片我们来了解一下fanout类型的Exchange. 1.Exchange的fanout类型 fanout类型的Exchange的特点是会把消 ...