hdu 4431 第37届ACM/ICPC 天津赛区现场赛A题 枚举
#include<stdio.h>
#include<iostream>
#include<string.h>
#include<algorithm>
using namespace std;
int cnt[];
bool judge4X3()
{
int ret=;
int tmp[];
for(int i=;i<;i++)tmp[i]=cnt[i]; for(int i=;i<=;i+=)
for(int j=;j<;j++)
{
if(tmp[i+j]>=) //相同的
{
tmp[i+j]-=;
ret++;
}
while(j+< && tmp[i+j] && tmp[i+j+] &&tmp[i+j+]) //不同的
{
tmp[i+j]--;
tmp[i+j+]--;
tmp[i+j+]--;
ret++;
}
}
for(int j=;j<;j++) //东西南北
{
if(tmp[+j]>=)
{
tmp[+j]-=;
ret++;
}
}
if(ret==)return true;
return false;
}
bool judge1() //判断对子和4个三连的情况
{
for(int i=;i<;i++)
{
if(cnt[i]>=)
{
cnt[i]-=;//枚举对子
if(judge4X3())
{
cnt[i]+=;
return true;
}
cnt[i]+=;
}
}
return false;
}
bool judge2() //判断全是对子的情况
{
for(int i=;i<;i++)
{
if(cnt[i]!= && cnt[i]!=)
return false;
}
return true;
}
bool judge3() //判断全部不相同的情况
{
for(int j=;j<;j++)
if(cnt[j+]==)
return false;
for(int i=;i<=;i+=)
{
if(cnt[i]== || cnt[i+]==)return false;
for(int j=;j<;j++) //不能再出现其他的牌
if(cnt[i+j]!=)
return false;
}
return true;
}
bool judge()
{
if(judge1() || judge2() || judge3())return true;
return false;
}
int main()
{
int T;
char str[];
scanf("%d",&T);
int ans[],tol;
while(T--)
{
memset(cnt,,sizeof(cnt));
for(int i=;i<;i++)
{
scanf("%s",&str);
int t=str[]-'';
if(str[]=='m')t+=;
else if(str[]=='s')t+=;
else if(str[]=='p')t+=;
else t+=;
cnt[t]++;
} //将麻将排个序
tol=;
for(int i=;i<;i++)
{
cnt[i]++;
if(cnt[i]<= && judge()) //麻将个数不能大于4,
ans[tol++]=i; //符合条件
cnt[i]--;
}
if(tol==)printf("Nooten\n");
else
{
printf("%d",tol);
for(int i=;i<tol;i++)
{
printf(" %d",(ans[i]%)+);
if(ans[i]/==)printf("m");
else if(ans[i]/==)printf("s");
else if(ans[i]/==)printf("p");
else printf("c");
}
printf("\n");
}
}
return ;
}
hdu 4431 第37届ACM/ICPC 天津赛区现场赛A题 枚举的更多相关文章
- hdu 4438 第37届ACM/ICPC 天津赛区现场赛H题
题意:Alice和Bob两个人去打猎,有两种(只)猎物老虎和狼: 杀死老虎得分x,狼得分y: 如果两个人都选择同样的猎物,则Alice得分的概率是p,则Bob得分的概率是(1-p): 但是Alice事 ...
- Substrings 第37届ACM/ICPC 杭州赛区现场赛C题(hdu 4455)
http://acm.hdu.edu.cn/showproblem.php?pid=4455 https://icpcarchive.ecs.baylor.edu/index.php?option=c ...
- zoj 3659 第37届ACM/ICPC 长春赛区现场赛E题 (并查集)
题意:给出一棵树,找出一个点,求出所有点到这个点的权值和最大,权值为路径上所有边权的最小值. 用神奇的并查集,把路按照权值从大到小排序,然后用类似Kruskal的方法不断的加入边. 对于要加入的一条路 ...
- hdu 4432 第37届ACM/ICPC天津现场赛B题
题目大意就是找出n的约数,然后把约数在m进制下展开,各个数位的每一位平方求和,然后按m进制输出. 模拟即可 #include<cstdio> #include<iostream> ...
- hdu 4435 第37届ACM/ICPC天津现场赛E题
转载请注明出处,谢谢http://blog.csdn.net/ACM_cxlove?viewmode=contents by---cxlove 题目:给出N个城市,从1开始需要遍历所有点,选择一 ...
- hdu 4461 第37届ACM/ICPC杭州赛区I题
题意:给两个人一些棋子,每个棋子有其对应的power,若b没有或者c没有,或者二者都没有,那么他的total power就会减1,total power最少是1,求最后谁能赢 如果b或c出现的话,fl ...
- hdu 4460 第37届ACM/ICPC杭州赛区H题 STL+bfs
题意:一些小伙伴之间有朋友关系,比如a和b是朋友,b和c是朋友,a和c不是朋友,则a和c之间存在朋友链,且大小为2,给出一些关系,求出这些关系中最大的链是多少? 求最短路的最大距离 #include& ...
- hdu 4462 第37届ACM/ICPC 杭州赛区 J题
题意:有一块n*n的田,田上有一些点可以放置稻草人,再给出一些稻草人,每个稻草人有其覆盖的距离ri,距离为曼哈顿距离,求要覆盖到所有的格子最少需要放置几个稻草人 由于稻草人数量很少,所以状态压缩枚举, ...
- hdu 4463 第37届ACM/ICPC杭州赛区K题 最小生成树
题意:给坐标系上的一些点,其中有两个点已经连了一条边,求最小生成树的值 将已连接的两点权值置为0,这样一定能加入最小生成树里 最后的结果加上这两点的距离即为所求 #include<cstdio& ...
随机推荐
- 用代码块在new对象时set属性
看到这样一种用法,很方便 request.setRequestHead(new RequestHeadType() {{ setRequestor("Online"); setRe ...
- bzoj千题计划266:bzoj4872: [六省联考2017]分手是祝愿
http://www.lydsy.com/JudgeOnline/problem.php?id=4872 一种最优解是 从大到小灯有亮的就灭掉 最优解是唯一的,且关灯的顺序没有影响 最优解 对每个开关 ...
- 玩转Hook——Android权限管理功能探讨(一)
随着Android设备上的隐私安全问题越来越被公众重视,恶意软件对用户隐私,尤其是对电话.短信等私密信息的威胁日益突出,各大主流安全软件均推出了自己的隐私行为监控功能,在root情况下能有效防止恶意软 ...
- javascritpt创建对象
javascript添加对象示例: <script> person=new Object(); person.firstname="Bill"; person.last ...
- mybatis查询缓存——(十三)
1. mybatis缓存介绍 如下图,是mybatis一级缓存和二级缓存的区别图解: mybatis提供查询缓存,用于减轻数据压力,提高数据库性能. mybaits提供一级缓存,和二级缓存.
- 关于sru源码class Model的parameters
class Model(nn.Module): def __init__(self, words, args): super(Model, self).__init__() self.args = a ...
- Paint Fence
There is a fence with n posts, each post can be painted with one of the k colors.You have to paint a ...
- 如何提升mysql replication的性能&多线程传输二进制日志
1,最好使用内网或者专线链路传输binlog数据 (千兆网卡.还不够的话,bounding 技术,扩展带宽) 在my.cnf中强制使用内网ip传输数据bind-address=ip2,将二进制保存在独 ...
- MySQL 5.6 Replication 复制 FAQ
原文请参照MySQL官方文档Reference Manual,版本5.6.10. 复制功能使得数据可以从一个MySQL数据库(master主库)复制到另一个或多个MySQL数据库(slave从库).缺 ...
- Linux获取/dev/input目录下的event对应的设备【转】
转自:https://blog.csdn.net/qq_21792169/article/details/51458855 当我们在Linux操作系统下使用input子系统时,当我们先插鼠标,在插上摄 ...