[NOIP2015] 斗地主 大爆搜
考试的时候想了半天,实在是想不到解决的办法,感觉只能暴力。。然后暴力也懒得打了,小数据模拟骗30分hhh
然而正解真的是暴力。。大爆搜。。
然后我的内心拒绝改这道题(TAT)
不过在wcx大佬的帮助下,还是成功的弄过去了。
首先我们明确两个显而易见的问题:答案与花色无关,与出牌顺序无关(废话)
然后我们的切入点是,顺子(连顺等)和带牌(三带一等),因为他们是出牌多的大户。
结论:顺子一定比带牌优(因为可以多出单张)。(不信你可以尝试举出反例)
然后既然这样,我们就先举出全部用带牌的步数,然后一点一点用顺子更新就行了。
有个技巧:按照顺子顺序编号:3,4,5,6···K,A,2。这样的话就可以在循环找顺子的时候方便
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
using namespace std;
#define pos(i,a,b) for(int i=(a);i<=(b);i++)
#define N 60
int t,n;
int size[N];
int getnum(int x){//小技巧
if(x==1)
return 12;
if(x==2)
return 13;
if(x==0)
return 14;
return x-2;
}
int ans;
int doit(){//找到当前剩余牌下全部带牌的最小步骤
int tmp=0;
int tp[10]={0};
pos(i,1,14){
tp[size[i]]++;
}
while(tp[4]&&tp[2]>=2){//四带二
tp[4]--;tp[2]-=2;tmp++;
}
while(tp[4]&&tp[1]>=2){//四带一
tp[4]--;tp[1]-=2;tmp++;
}
while(tp[3]&&tp[2]>=1){//三带二
tp[3]--;tp[2]-=1;tmp++;
}
while(tp[3]&&tp[1]>=1){//三带一
tp[3]--;tp[1]-=1;tmp++;
}
tmp+=tp[1]+tp[2]+tp[3]+tp[4];//单牌
return tmp;
}
void dfs(int cnt){
if(cnt>ans)
return;
int x=doit();
ans=min(ans,cnt+x);
pos(i,1,11){//三连对
int j;
for(j=i;size[j]>=3&&j<=12;j++);
if(j-i<2)
continue;
for(int k=j;k-i>=2;k--){
pos(l,i,k-1)
size[l]-=3;
dfs(cnt+1);
pos(l,i,k-1)
size[l]+=3;
}
}
pos(i,1,10){//连对
int j;
for(j=i;size[j]>=2&&j<=12;j++);
if(j-i<3)
continue;
for(int k=j;k-i>=3;k--){
pos(l,i,k-1)
size[l]-=2;
dfs(cnt+1);
pos(l,i,k-1)
size[l]+=2;
}
}
pos(i,1,8){//顺子
int j;
for(j=i;size[j]>=1&&j<=12;j++);
if(j-i<5)
continue;
for(int k=j;k-i>=5;k--){
pos(l,i,k-1)
size[l]--;
dfs(cnt+1);
pos(l,i,k-1){
size[l]++;
}
}
}
}
int main(){
scanf("%d%d",&t,&n);
while(t--){
memset(size,0,sizeof(size));
pos(i,1,n){
int x,y;
scanf("%d%d",&x,&y);
size[getnum(x)]++;
}
ans=doit();
dfs(0);
printf("%d\n",ans);
}
return 0;
}
[NOIP2015] 斗地主 大爆搜的更多相关文章
- noip 2015 斗地主 大爆搜!!!
反正肯定是大模拟 但是每一个可以出的牌都搜一定不是最优的 考虑最特殊的出牌方案:顺子(单,对,三) 每一种方案再加上暴力贪心打出剩下的牌的步数 #include<cstdio> #incl ...
- bzoj4325: NOIP2015 斗地主(爆搜+模拟)
去年的我还不会打斗地主呵呵 觉得这道题挺难的..抄了一遍题解,感触挺多的= = 首先出牌的方式太多了不能每次都枚举所有的出牌方式, 于是分成两部分:1.顺子 2.带牌等其他 每次dfs都搜顺子,而且顺 ...
- [NOIP2009] 靶形数独 骚气的大爆搜
这两天OD留的题是搜索,这个东西,就是历年的NOIP压轴题嘛.做了几道什么斗地主啊啥的,感觉还是这题我还懂点. 这道题的搜(xia)索(da)思路是这样的:预处理出一切能处理的东西. 数独大家都了解吧 ...
- NOIP2013华容道 大爆搜
预处理出每个点周围四个点互相到达的最短路,再在整个图上跑SPFA,要记录路径 #include<cstdio> #include<cstring> #include<io ...
- NOIP2015斗地主题解 7.30考试
问题 B: NOIP2015 斗地主 时间限制: 3 Sec 内存限制: 1024 MB 题目描述 牛牛最近迷上了一种叫斗地主的扑克游戏.斗地主是一种使用黑桃.红心.梅花.方片的A到K加上大小王的共 ...
- [补档][NOIP2015] 斗地主
[NOIP2015] 斗地主 题目 传送门:http://cogs.pro/cogs/problem/problem.php?pid=2106 INPUT 第一行包含用空格隔开的2个正整数Tn,表示手 ...
- [NOIP2015] 斗地主(搜索)
题目描述 牛牛最近迷上了一种叫斗地主的扑克游戏.斗地主是一种使用黑桃.红心.梅花.方片的A到K加上大小王的共54张牌来进行的扑克牌游戏.在斗地主中,牌的大小关系根据牌的数码表示如下:3<4< ...
- POJ 1166 The Clocks (爆搜 || 高斯消元)
题目链接 题意: 输入提供9个钟表的位置(钟表的位置只能是0点.3点.6点.9点,分别用0.1.2.3)表示.而题目又提供了9的步骤表示可以用来调正钟的位置,例如1 ABDE表示此步可以在第一.二.四 ...
- hdu4536-XCOM Enemy Unknown(爆搜)
XCOM-Enemy Unknown是一款很好玩很经典的策略游戏. 在游戏中,由于未知的敌人--外星人入侵,你团结了世界各大国家进行抵抗.随着游戏进展,会有很多的外星人进攻事件.每次进攻外星人会选择3 ...
随机推荐
- 1.如何安装matlab2016a
下载:见网盘 安装教程: 解压安装文件,安装文件为 iso 格式,但是不能通过虚拟光驱安装,需要将 iso 文件用解压软件解压.注意,R2016b_win64_dvd1.iso 和 R2016b_wi ...
- 序列、视图、索引(面试看这个就GO了)
oracle内置对象 序列.视图.索引 序列 create sequence aaa start with 1; 使用 视图 创建好之后 然后直接用 就OK了 有了视图可以代替子查询,使得sql简洁 ...
- ASP.NET Core Web 资源打包与压缩
本文将介绍使用的打包和压缩的优点,以及如何在ASP.NET Core应用程序中使用这些功能. 概述 在ASP.Net中可以使用打包与压缩这两种技术来提高Web应用程序页面加载的性能.通过减少从服务器请 ...
- KBEngine简单RPG-Demo源码解析(2)
七:服务端资产库文件夹结构http://kbengine.org/cn/docs/concepts/directorys.html看assets, 注意:demo使用的不是默认的assets资产目录, ...
- KBEngine简单RPG-Demo源码解析(1)
一:环境搭建1. 确保已经下载过KBEngine服务端引擎,如果没有下载请先下载 下载服务端源码(KBEngine): https://github.com ...
- Tagged Pointer
前言 在2013年9月,苹果推出了iPhone5s,与此同时,iPhone5s配备了首个采用64位架构的A7双核处理器,为了节省内存和提高执行效率,苹果提出了Tagged Pointer的概念.对于6 ...
- Linux - iostat命令详解
简介 iostat可以提供更丰富的IO性能状态数据,iostat命令有两个用途: 输出CPU的统计信息 输出设备和分区的I/O统计信息 命令语法及参数说明 语法: iostat [ -c | -d ] ...
- Java IO在实际开发中的应用
IO是java绕不过去的槛,在开发中io无处不在, 正如同 世界上本没有路,java io写多了,也就知道了大体是什么意思,在读完thinking in java 感觉就更清晰了,结合具体的业务场景, ...
- .NetCore~Json代替了Xml
回到目录 在进行.netCore时代后,最大的变化就是对Json的使用更加主动,基本代替了之前的XML,像一些用户配置,系统配置,包包配置等都是基于json的,而web.config这个文件基本变成一 ...
- ASP.NET Core MVC 过滤器介绍
过滤器的作用是在 Action 方法执行前或执行后做一些加工处理.使用过滤器可以避免Action方法的重复代码,例如,您可以使用异常过滤器合并异常处理的代码. 过滤器如何工作? 过滤器在 MVC Ac ...