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. TCP与UDP与HTTP协议

    http:是用于www浏览的一个协议.tcp:是机器之间建立连接用的到的一个协议. 1.TCP/IP是个协议组,可分为三个层次:网络层.传输层和应用层.在网络层有IP协议.ICMP协议.ARP协议.R ...

  2. ubuntu mysql导出数据库及数据

    mysqldump -u root -p mask_rcnn_realsense > /home/luo/mask_rcnn_realsense1.sql

  3. Opencv Canny

    #include <iostream>#include <opencv2/opencv.hpp> using namespace std;using namespace cv; ...

  4. adf笔记

    1>jsf页面js调试,手动添加debugger调试 方案:在页面中添加debugger,然后打开“开发者工具”(必须打开),直接运行页面自动跳转到debugger处. 2>jdevelo ...

  5. C程序之包含头文件

    在C程序中包含文件有以下两种方法: 方法一:#include<XXX.h> 这里的XXX一般是改动较小的标准库,用符号"<"和">"将要 ...

  6. CSS块级元素、内联元素概念[转]

    CSS文档流与块级元素(block).内联元素(inline),之前翻阅不少书籍,看过不少文章, 看到所多的是零碎的CSS布局基本知识,比较表面.看过O'Reilly的<CSS权威指南>, ...

  7. MYSQl修改临时文件目录

    MSYQL在执行查询语句时报出以下错误: ERROR 3(HY000):Error writing file 'tmp/MY1yjZEI'(Errcode:28) 看了下/tmp所在目录的磁盘情况,发 ...

  8. 最大公约数(gcd)和 最小公倍数(lcm)——辗转相除法

    辗转相除法(又称欧几里得算法)是求最大公因数的算法 要求a,b的最大公约数(a>b),我们可以递归地求b,a%b的最大公约数,直到其中一个数变成0,这时另一个数就是a,b的最大公约数. C++实 ...

  9. [Training Video - 3] [Groovy in Detail] Non-static and Static functions, initializing log inside class

    log.info "starting" // we use class to create objects of a class Planet p1 = new Planet() ...

  10. 前台的json数组转化为List<T>集合

    using System;using System.Collections.Generic;using System.Linq;using System.Runtime.Serialization;u ...