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 斗地主增强版的更多相关文章

  1. Luogu 2540 斗地主增强版(搜索,动态规划)

    Luogu 2540 斗地主增强版(搜索,动态规划) Description 牛牛最近迷上了一种叫斗地主的扑克游戏.斗地主是一种使用黑桃.红心.梅花.方片的A到K加上大小王的共54张牌来进行的扑克牌游 ...

  2. 洛谷 题解 P2540 【斗地主增强版】

    [分析] 暴力搜顺子,贪心出散牌 为什么顺子要暴力? 玩过斗地主的都知道,并不是出越长的顺子越好,如果你有一组手牌,3,4,5,6,7,6,7,8,9,10,你一下把最长的出了去,你会单两张牌,不如出 ...

  3. [Luogu2540][NOIP2016]斗地主增强版(搜索+DP)

    增强版就是原版中两鬼不算对子的版本. 先爆搜出完所有对子,剩下的牌DP处理. 考虑每个数码的拆牌情况,最多可能被拆成5种情况:1+1+1+1,1+1+2,1+3,2+2,4.故DP状态数最多为5^13 ...

  4. luogu2540 斗地主增强版

    题目大意 给你一副手牌,没有飞机带翅膀,按斗地主的规则,求将所有牌打出的最少次数. 题解 先不考虑顺子 我们已经知道花色对牌没有影响,那么如果不考虑顺子,每个牌具体是什么数字我们也用不着知道,我们关心 ...

  5. Luogu2540 斗地主增强版(搜索+动态规划)

    单纯的暴搜似乎还是很好写的,然而过不了.出完顺子之后答案是可以dp出来的,于是大力搜然后大力dp就好了. dp时强行讨论完了几乎所有拆牌情况,理性愉悦一发. #include<iostream& ...

  6. 【NOIP2015】斗地主 D1 T3 及 增强版 (送命题)

    恶心送命模拟题 暴搜顺子,DP预处理剩下的. 由于官方数据太水,很多情况没有讨论的都能过普通版本,想要测试自己代码正确性的同学们可以交交这道题,有很多dalao给出了hack数据 : Luogu P2 ...

  7. 将表里的数据批量生成INSERT语句的存储过程 增强版

    将表里的数据批量生成INSERT语句的存储过程 增强版 有时候,我们需要将某个表里的数据全部或者根据查询条件导出来,迁移到另一个相同结构的库中 目前SQL Server里面是没有相关的工具根据查询条件 ...

  8. 最新GHOST XP系统下载旗舰增强版 V2016年

    系统来自:系统妈:http://www.xitongma.com 深度技术GHOST xp系统旗舰增强版 V2016年3月 系统概述 深度技术ghost xp系统旗舰增强版集合微软JAVA虚拟机IE插 ...

  9. 最新深度技术GHOST XP系统旗舰增强版 V2016年

    来自系统妈:http://www.xitongma.com 深度技术GHOST xp系统旗舰增强版 V2016年 系统概述 深度技术ghost xp系统旗舰增强版集合微软JAVA虚拟机IE插件,增强浏 ...

随机推荐

  1. CGAffineTransformMake 矩阵变换 的运算原理(转)

    1.矩阵的基本知识: struct CGAffineTransform { CGFloat a, b, c, d; CGFloat tx, ty; }; CGAffineTransform CGAff ...

  2. ROS tf 编程指南

    ROS (Robot Operating System, 机器人操作系统)是最知名的机器人操作系统,广泛应用于无人驾驶和机器人,tf(transforms,坐标系转换)是ROS下的一个常用的工具库.r ...

  3. 无网络安装mysql步骤

    1. 先安装Microsoft Visual C++ 2010 运行环境,运行vcredist_x86.exe文件: 2. 安装MySql数据库,运行mysql-installer-community ...

  4. java工具jar包—Lombok

    如何引入 maven工程,直接引入lombok的jar依赖即可: <dependency> <groupId>org.projectlombok</groupId> ...

  5. archives of source

    "ubuntu 暂时不能解析域名 archive.ubuntu.com"怎么办? root下输入命令:lsb_release -a用来查询Ubuntu版本号 登录网站 http:/ ...

  6. STL扩展容器

    string | array | hash 1. string - 可以视为以字符为元素的一种容器, 可以在字符上进行遍历, 提供begin()/end() - 为了支持迭代器和迭代器适配器 , st ...

  7. javascript总结30 :DOM事件

    事件: 1 在js中可以说一整套事件能完成一个功能: 事件的定义:当什么时候执行什么事: 使用事件的基本结构:事件源+事件类型=执行的指令 2 事件三要素:事件源 事件类型, 驱动程序(匿名函数). ...

  8. javascript总结26:Date

    1 获取Date对象 Date-引用类型,JavaScript中的内置对象 获取当前时间 var date = new Date(); //UTC的时间 //返回数字,时间的毫秒形式 var date ...

  9. CodeForces 288C Polo the Penguin and XOR operation (位运算,异或)

    题意:给一个数 n,让你求一个排列,使得这个排列与0-n的对应数的异或之最大. 析:既然是异或就得考虑异或的用法,然后想怎么才是最大呢,如果两个数二进制数正好互补,不就最大了么,比如,一个数是100, ...

  10. 关于Qt官方下载页的最新变动

    时间过得很快,现在Qt已经迎来了5.10版本,但是当我们去下载页下载对应安装包的时候,已经找不到之前的offline安装包了.你能够看到的只有在线安装包,并且我自己有做过测试,国内的网络基本上没有机会 ...