题面戳我

题解

我原来也觉得是一道不可做的难题。。

其实,,,很简单的啦。。。

对于当前状态

我们出牌的方式大致分为两类

一类是不用考虑点数的,包括单张,对子,三带一等

另一类就是需要考虑点数的,包括顺子等

因此,每种状态下,首先考虑不用考虑点数的出牌方法

尝试打完,更新打完。

搜索的作用是考虑要考虑点数的出牌方法

每次搜索去掉若干张牌,然后递归,继续考虑不考虑点数的出牌方法。

然后就发现这道题目特别简单啦。。。

(还没懂就看代码吧。。。)

#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<set>
#include<map>
#include<vector>
using namespace std;
inline int read()
{
int x=0,t=1;char ch=getchar();
while((ch<'0'||ch>'9')&&ch!='-')ch=getchar();
if(ch=='-')t=-1,ch=getchar();
while(ch<='9'&&ch>='0')x=x*10+ch-48,ch=getchar();
return x*t;
}
int ans,N,a[20];
void DFS(int st)
{
if(st>ans)return;
int b[5];
b[1]=b[2]=b[3]=b[4]=0;
for(int i=1;i<=14;++i)b[a[i]]++;
//方式1:四张带两张/对
for(int i=1;i<=14;++i)
if(a[i]==4)
{
if(b[1]>1){b[1]-=2;continue;}//带走两张单牌
else if(b[2]>1){b[2]-=2;continue;}//带走两对牌
else if(b[2]){b[2]--;continue;}//只能带走一对
}
//方式2:三张带一张/对
for(int i=1;i<=14;++i)
{
if(a[i]==3)
{
if(b[1])b[1]--;//带一张
else if(b[2])b[2]--;//带一对
}
}
ans=min(st+b[1]+b[2]+b[3]+b[4],ans);//上面的出牌方式和ans比较
//接下来的方式需要考虑牌的点数
int pos;
for(int i=1;i<=8;++i)//顺子的开始位置
{
pos=12;
for(int j=i;j<13;++j)//最多打到A
{
a[j]--;//打出顺子
if(a[j]==-1){pos=j;break;}//没有这么多牌呀。。。
if(j-i>3)DFS(st+1);//打出了一个顺子
}
while(pos>=i)a[pos--]++;//回溯
}
for(int i=1;i<=10;++i)
{
pos=12;
for(int j=i;j<13;++j)
{
a[j]-=2;
if(a[j]<0){pos=j;break;}
if(j-i>1)DFS(st+1);//一个双顺子
}
while(pos>=i)a[pos--]+=2;
}
for(int i=1;i<=11;++i)
{
pos=12;
for(int j=i;j<13;++j)
{
a[j]-=3;
if(a[j]<0){pos=j;break;}
if(j-i)DFS(st+1);
}
while(pos>=i)a[pos--]+=3;
}
}
int main()
{
int T=read();N=read();
while(T--)
{
memset(a,0,sizeof(a));
for(int i=1;i<=N;++i)
{
int x=read(),y=read();
if(x==0)a[14]++;
else if(x<3)a[x+11]++;
else a[x-2]++;
}
ans=N;
DFS(0);
printf("%d\n",ans);
}
return 0;
}

【NOIP2015】斗地主(搜索,贪心)的更多相关文章

  1. 【BZOJ4325】NOIP2015 斗地主 搜索+贪心

    这个东西考试的时候一眼以为状压就压炸了考试又了一下午.....最后我打出来发现后几个点10min都过不去,我大概算了一下,可能是吧.......最后一脸懵逼的我去怂了正解,我们发现只要确定了顺子就可以 ...

  2. NOIP2015斗地主[DFS 贪心]

    题目描述 牛牛最近迷上了一种叫斗地主的扑克游戏.斗地主是一种使用黑桃.红心.梅花.方片的A到K加上大小王的共54张牌来进行的扑克牌游戏.在斗地主中,牌的大小关系根据牌的数码表示如下:3<4< ...

  3. 【BZOJ4325】NOIP2015 斗地主 搜索+剪枝

    [BZOJ4325]NOIP2015 斗地主 Description 牛牛最近迷上了一种叫斗地主的扑克游戏.斗地主是一种使用黑桃.红心.梅花.方片的A到K加上大小王的共54张牌来进行的扑克牌游戏.在斗 ...

  4. 2018.11.01 bzoj4325: NOIP2015 斗地主(贪心+搜索)

    传送门 原来一直以为是一道大模拟. 没想到是一道搜索+最优性剪枝 如何搜最优呢? 我们考虑怎么最快出完. 大概是应该尽量出当前能出出去最多的吧. 于是我们选择优先出顺子. 这样做有什么好处呢? 我们会 ...

  5. 洛谷 2668&2540 斗地主——搜索+贪心+dp

    题目:https://www.luogu.org/problemnew/show/P2540 发现如果没有顺子,剩下的可以贪心.所以搜索顺子怎么出,然后贪心. 这样只能过不加强版.原因是贪心的时候难以 ...

  6. 洛谷 P2668 & P2540 [ noip 2015 ] 斗地主 —— 搜索+贪心

    题目:https://www.luogu.org/problemnew/show/P2668   https://www.luogu.org/problemnew/show/P2540 首先,如果没有 ...

  7. LOJ2422 NOIP2015 斗地主 【搜索+贪心】*

    LOJ2422 NOIP2015 斗地主 LINK 题目大意很简单,就是问你斗地主的一分手牌最少多少次出完 然后我们发现对于一种手牌状态,不考虑顺子的情况是可以贪心做掉的 然后我们直接枚举一下顺子出牌 ...

  8. NOIP2015 斗地主(搜索+剪枝)

    4325: NOIP2015 斗地主 Time Limit: 30 Sec  Memory Limit: 1024 MBSubmit: 270  Solved: 192[Submit][Status] ...

  9. 2106. [NOIP2015] 斗地主

        2106. [NOIP2015] 斗地主 ★★★☆   输入文件:landlords.in   输出文件:landlords.out   简单对比 时间限制:2 s   内存限制:1025 M ...

  10. BZOJ 4325: NOIP2015 斗地主

    4325: NOIP2015 斗地主 Time Limit: 30 Sec  Memory Limit: 1024 MBSubmit: 684  Solved: 456[Submit][Status] ...

随机推荐

  1. 试着把.net的GC讲清楚(1)

    什么是GC? GC(garbage collection)是对内存管理中回收已经不用的内存的一种机制,我们熟知的java和.net都有自己的GC机制,是内存管理的一部分. 为什么会有GC呢?是因为动态 ...

  2. 把页面的Table直接输出到Excel文件中

    有个需求是统计的时候,为生成的html表格提供导出功能,但是这样导出Excel不会显示自身的表格 影响美观,但是excel会显示html的css样式,这里可以通过处理行对象的方式进行导出,但是处理起纵 ...

  3. PLECS_直流电机基本系统模型

    1.模型图 2.模型仿真结果 (1)Step阶跃t=1s,R=20Ω,V_dc = 120V,那么此时 电源电压波形: 电机电枢电流波形: 电机电磁转矩: 电机转速波形: (2)其他参数不变将R=30 ...

  4. 洛谷P1854 花店橱窗布置 分析+题解代码

    洛谷P1854 花店橱窗布置 分析+题解代码 蒟蒻的第一道提高+/省选-,纪念一下. 题目描述: 某花店现有F束花,每一束花的品种都不一样,同时至少有同样数量的花瓶,被按顺序摆成一行,花瓶的位置是固定 ...

  5. jq模仿雨滴下落的动画

    效果如图: 实现思路:定时器每隔x秒生成宽高.下落速度(即动画执行时间).left随机的div. 1.CSS: body{ overflow: hidden;/*这是为了防止出现滚动条*/ } .co ...

  6. 网页版仿Excel效果组件--handsontable拓展运用

    引言(祝看官们新年万事大吉) 前段时间项目需要实现网页版的excel表格功能,瞬间就想到了handsontable,为什么呢?理由如下:该UI组件功能齐全多样,展示效果也更贴近bootstrap风格, ...

  7. CentOS 6安装Oracle报错解决方案

    1. Preparing to launch Oracle Universal Installer from /tmp/OraInstall2017-05-23_04-18-48AM. Please ...

  8. Maven中模块的聚合以及对jar包的继承

    我需要将之前的A B C三个模块聚合到一个一个工程中ABC项目中 pom.xml文件中应该这样配置 1.修改packaging里面的配置 <!-- 用于聚合这个项目的时候应该将packaging ...

  9. Linux下ACL权限控制以及用sudo设置用户对命令的执行权限

    ACL权限分配 1.setfacl命令设置文件权限 setfacl -m u:user1:rw root.txt setfacl -m u:user2:rwx root.txt 2.getfacl命令 ...

  10. 老男孩Python全栈开发(92天全)视频教程 自学笔记08

    day8课程内容: 文件操作 f=open('小重山','r',encoding='utf8')   #以读的方式打开文件 data=f.read() print(data) f.close()  # ...