洛谷 P2668 斗地主
毒瘤题目,搞了三天……
也没什么好讲的,就是纯搜索,先搜顺子,再搜其他的,最后单张牌和对子的时候,就不要搜索了,直接枚举,不然会T飞掉多么痛的领悟……
主要还是靠码力
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
int t,n;
int card[25],sp[25],ans=0x7fffff;
int x;
inline int read()
{
int k=0,f=1;
char c=getchar();
for(;!isdigit(c);c=getchar())
if(c=='-')
f=-1;
for(;isdigit(c);c=getchar())
k=(k<<3)+(k<<1)+c-48;
return k*f;
}
void dfs(int sum,int step)
{
if(sum<0||step>=ans)
return;
if(sum==0)
{
ans=min(ans,step);
return ;
}
//============顺子
int flag[101]={0},tot=0,pc[101]={0};
flag[3]=flag[2]=flag[1]=0; tot=0;
for(int i=3;i<=14;i++)
{
if(card[i]>=3)
{
flag[3]++;
pc[++tot]=i;
}
else
{
flag[3]=0;
tot=0;
continue;
}
if(flag[3]>=2)
{
for(int j=1;j<=tot;j++)
{
card[pc[j]]-=3;
}
dfs(sum-3*tot,step+1);
for(int j=1;j<=tot;j++)
{
card[pc[j]]+=3;
}
}
}
tot=0;
for(int i=3;i<=14;i++)
{
if(card[i]>=2)
{
flag[2]++;
pc[++tot]=i;
}
else
{
flag[2]=0;
tot=0;
continue;
}
if(flag[2]>=3)
{
for(int j=1;j<=tot;j++)
{
card[pc[j]]-=2;
}
dfs(sum-2*tot,step+1);
for(int j=1;j<=tot;j++)
{
card[pc[j]]+=2;
}
}
}
tot=0;
for(int i=3;i<=14;i++)
{
if(card[i]>=1)
{
flag[1]++;
pc[++tot]=i;
}
else
{
flag[1]=0;
tot=0;
continue;
}
if(flag[1]>=5)
{
for(int j=1;j<=tot;j++)
{
card[pc[j]]-=1;
}
dfs(sum-tot,step+1);
for(int j=1;j<=tot;j++)
{
card[pc[j]]+=1;
}
}
}
//========四带
flag[11]=flag[12]=0;
for(int i=3;i<=15;i++)
{
if(card[i]>=4)
{
card[i]-=4;
for(int j=0;j<=15;j++)
{
if(card[j]>=4)
{
card[j]-=4;
dfs(sum-8,step+1);
card[j]+=4;
}
if(card[j]>=2)
{
card[j]-=2;
for(int k=3;k<=15;k++)
{
if(card[k]>=2)
{
card[k]-=2;
dfs(sum-8,step+1);
card[k]+=2;
}
}
dfs(sum-6,step+1);
card[j]+=2;
}
if(card[j]>0)
{
for(int k=0;k<15;k++)
{
if(card[k]>0)
{
if(j==k)
continue;
card[j]-=1; card[k]-=1;
dfs(sum-6,step+1);
card[j]+=1; card[k]+=1;
}
}
}
}
dfs(sum-4,step+1);
card[i]+=4;
}
}
//======三带
flag[11]=flag[12]=0;
for(int i=1;i<=15;i++)
{
if(card[i]>=3)
{
card[i]-=3;
for(int j=0;j<=15;j++)
{
if(i==j)
continue;
if(card[j]>=1)
{
card[j]-=1;
dfs(sum-4,step+1);
card[j]+=1;
}
if(card[j]>=2&&j!=0)
{
card[j]-=2;
dfs(sum-5,step+1);
card[j]+=2;
}
}
dfs(sum-3,step+1);
card[i]+=3;
}
}
//单张+对子
flag[32]=0,flag[5]=0;
for(int i=0;i<=15;i++)
{
if(card[i]==2)
{
flag[5]++;
}
if(card[i]==1)
{
flag[32]++;
}
}
if(sum-2*flag[5]-flag[32]==0)
ans=min(ans,step+flag[5]+flag[32]);
}
int main()
{
t=read(),n=read();
while(t--)
{
ans=0x7fffff;
memset(card,0,sizeof(card));
for(int i=1;i<=n;i++)
{
int col,x;
x=read(),col=read();
if(x==1||x==2)
card[13+x]++;
else
card[x]++;
}
dfs(n,0);
printf("%d\n",ans);
}
return 0;
}
洛谷 P2668 斗地主的更多相关文章
- 洛谷P2668 斗地主==codevs 4610 斗地主[NOIP 2015 day1 T3]
P2668 斗地主 326通过 2.6K提交 题目提供者洛谷OnlineJudge 标签搜索/枚举NOIp提高组2015 难度提高+/省选- 提交该题 讨论 题解 记录 最新讨论 出现未知错误是说梗啊 ...
- [NOIP2015] 提高组 洛谷P2668 斗地主
题目描述 牛牛最近迷上了一种叫斗地主的扑克游戏.斗地主是一种使用黑桃.红心.梅花.方片的A到K加上大小王的共54张牌来进行的扑克牌游戏.在斗地主中,牌的大小关系根据牌的数码表示如下:3<4< ...
- 洛谷P2668 斗地主 [NOIP2015]
题目描述 牛牛最近迷上了一种叫斗地主的扑克游戏.斗地主是一种使用黑桃.红心.梅花.方片的A到K加上大小王的共54张牌来进行的扑克牌游戏.在斗地主中,牌的大小关系根据牌的数码表示如下:3<4< ...
- 洛谷P2668斗地主(搜索)noip2015
题目描述 牛牛最近迷上了一种叫斗地主的扑克游戏.斗地主是一种使用黑桃.红心.梅花.方片的A到K加上大小王的共54张牌来进行的扑克牌游戏.在斗地主中,牌的大小关系根据牌的数码表示如下:3<4< ...
- 洛谷—— P2668 斗地主
https://www.luogu.org/problem/show?pid=2668 题目描述 牛牛最近迷上了一种叫斗地主的扑克游戏.斗地主是一种使用黑桃.红心.梅花.方片的A到K加上大小王的共54 ...
- 洛谷P2668 斗地主
好,终于搞完了这一道毒瘤题...... 先想到搜索,然后想到状压,发现数据组数很多,又是随机,还是决定用搜索. 先搜出的多的,于是顺序是三个顺子,然后按照多到少搜带牌,最后是不带牌. 大体思路很简单, ...
- 题解【洛谷P2668】[NOIP2015]斗地主
题目描述 牛牛最近迷上了一种叫斗地主的扑克游戏.斗地主是一种使用黑桃.红心.梅花.方片的 $ A $ 到 $ K $ 加上大小王的共 $ 54 $ 张牌来进行的扑克牌游戏.在斗地主中,牌的大小关系根据 ...
- 洛谷 P2668 & P2540 [ noip 2015 ] 斗地主 —— 搜索+贪心
题目:https://www.luogu.org/problemnew/show/P2668 https://www.luogu.org/problemnew/show/P2540 首先,如果没有 ...
- 【noip】跟着洛谷刷noip题
传送门 1.铺地毯 d1t1 模拟 //Twenty #include<cstdio> #include<cstdlib> #include<iostream> # ...
随机推荐
- OpenGL ES入门详解
http://blog.csdn.net/wangyuchun_799/article/details/7736928 1.决定你要支持的OpenGL ES的版本.目前,OpenGL ES包含1.1 ...
- Mycat(1)
https://www.jianshu.com/p/26513f428ecf https://blog.csdn.net/fly910905/article/details/87101059 http ...
- bzoj1125:[POI2008]Poc
传送门 这个题好难卡啊. 看到这种题自然会想到字符串hash是不是,但是对于每次操作造成的影响需要\(O(n)\)的时间去更新,自然是不优的 可以发现这个更新可以用数据结构来维护,对于每个hash值开 ...
- time库的使用
首先只需要 import time (典型的,标准的python库的使用方法) 主要包括三类函数 ——时间获取:time() , ctime() , gmtime() ——时间格式化: strftim ...
- [题解](树形dp/换根)小x游世界树
2. 小x游世界树 (yggdrasi.pas/c/cpp) [问题描述] 小x得到了一个(不可靠的)小道消息,传说中的神岛阿瓦隆在格陵兰海的某处,据说那里埋藏着亚瑟王的宝藏,这引起了小x的好奇,但当 ...
- js字符串与正则匹配
这里就说一下具体的使用方法,不做过多的解释. 字符串匹配正则的方法:str.方法(reg) 1.str.search() 参数是正则,将会从开始查找字符串中与正则匹配的字符,并返回该字符的第一次出现的 ...
- 洛谷 P1593 因子和 || Sumdiv POJ - 1845
以下弃用 这是一道一样的题(poj1845)的数据 没错,所有宣称直接用逆元/快速幂+费马小定理可做的,都会被hack掉(包括大量题解及AC代码) 什么原因呢?只是因为此题的模数太小了...虽然990 ...
- (转)Unity3D中常用的数据结构总结与分析
http://www.cnblogs.com/murongxiaopifu/p/4161648.html#array 1.几种常见的数据结构 常碰到的几种数据结构:Array,ArrayList, ...
- Java环境安装与Eclipse安装
1.jdk下载安装 2.Eclipse下载安装 遇到的问题: 出现问题原因可能有两个:1)没有配置环境变量 2)jdk和eclipse安装的版本不一致,都是64位或者都是32位. 本人出现错误的原因: ...
- 【Linux】使用Cockpit进行主机管理
Cockpit 进行主机监控 官网文档: https://cockpit-project.org/running.html 版本信息 针对Red Hat [root@master ~]# cat /e ...