1028: [JSOI2007]麻将

Time Limit: 1 Sec  Memory Limit: 162 MB
Submit: 2638  Solved: 1168
[Submit][Status][Discuss]

Description

  麻将是中国传统的娱乐工具之一。麻将牌的牌可以分为字牌(共有东、南、西、北、中、发、白七种)和序数
牌(分为条子、饼子、万子三种花色,每种花色各有一到九的九种牌),每种牌各四张。在麻将中,通常情况下一
组和了的牌(即完成的牌)由十四张牌组成。十四张牌中的两张组成对子(即完全相同的两张牌),剩余的十二张
组成三张一组的四组,每一组须为顺子(即同花色且序数相连的序数牌,例如条子的三、四、五)或者是刻子(即
完全相同的三张牌)。一组听牌的牌是指一组十三张牌,且再加上某一张牌就可以组成和牌。那一张加上的牌可以
称为等待牌。在这里,我们考虑一种特殊的麻将。在这种特殊的麻将里,没有字牌,花色也只有一种。但是,序数
不被限制在一到九的范围内,而是在1到n的范围内。同时,也没有每一种牌四张的限制。一组和了的牌由3m + 2张
牌组成,其中两张组成对子,其余3m张组成三张一组的m组,每组须为顺子或刻子。现给出一组3m + 1张的牌,要
求判断该组牌是否为听牌(即还差一张就可以和牌)。如果是的话,输出所有可能的等待牌。

Input

  包含两行。第一行包含两个由空格隔开整数n, m (9<=n<=400, 4<=m<=1000)。第二行包含3m + 1个由空格隔开
整数,每个数均在范围1到n之内。这些数代表要求判断听牌的牌的序数。

Output

  输出为一行。如果该组牌为听牌,则输出所有的可能的等待牌的序数,数字之间用一个空格隔开。所有的序数
必须按从小到大的顺序输出。如果该组牌不是听牌,则输出"NO"。

Sample Input

9 4
1 1 2 2 3 3 5 5 5 7 8 8 8

Sample Output

6 7 9
刚开始看这题觉得应该是个非常繁琐的搜索。。。然后发现牌的总的数字比较小,然后就有了一个奇怪的思路,不如直接枚举所有可能出现的牌,然后判断它是否是一张听牌就行了。。。
然后发现这个思路并没有什么大问题。对于所有的牌进行桶排计数,然后可以发现的是一个牌如果能组成三个的刻子,那么就组成刻子,剩下的牌和后面的组成顺子,就不会发生冲突。
代码如下:
#pragma comment(linker, "/STACK:1024000000,1024000000")
#include <iostream>
#include <cstdlib>
#include <cmath>
#include <string>
#include <cstring>
#include <cstdio>
#include <algorithm>
#include <queue>
#include <set>
#include <map>
#define re register
#define max(a,b) ((a)>(b)?(a):(b))
#define min(a,b) ((a)<(b)?(a):(b))
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
#define ms(arr) memset(arr, 0, sizeof(arr))
const int inf = 0x3f3f3f3f;
int n,m,cnt[2001],f[2001],tot,flag,ans[2001];
inline int read()
{int x=0,c=1;char ch=' ';while((ch>'9'||ch<'0')&&ch!='-')ch=getchar();while(ch=='-') c*=-1,ch=getchar();while(ch<='9'&&ch>='0')x=x*10+ch-'0',ch=getchar();return x*c;
}
int main()
{//freopen("date.in","r",stdin);n=read();m=read();for(re int i=0;i<=3*m;i++){int d=read();cnt[d]++;}for(re int i=1;i<=n;i++){cnt[i-1]--;cnt[i]++;flag=0;for(re int j=1;j<=n;j++){if(cnt[j]>=2){if(flag) break;int bj=0;for(re int k=1;k<=n;k++) f[k]=cnt[k];f[j]-=2;f[n+1]=f[n+2]=0;for(re int k=1;k<=n;k++){if(f[k]<0){bj=1;break;}f[k]%=3;f[k+1]-=f[k];f[k+2]-=f[k];}if(f[n+1]<0||f[n+2]<0) bj=1;if(bj==0) flag=1,ans[++tot]=i;}}}if(!tot) cout<<"NO";else for(re int i=1;i<=tot;i++)printf("%d ",ans[i]);return 0;
}

转载于:https://www.cnblogs.com/victorique/p/8808050.html

1028: [JSOI2007]麻将相关推荐

  1. bzoj 1028: [JSOI2007]麻将

    暴力枚举+贪心 1 #include<cstdio> 2 #include<iostream> 3 #include<cstring> 4 #include< ...

  2. [JSOI2007]麻将

    https://www.zybuluo.com/ysner/note/1218522 题面 有\(3m+1\)张牌,范围\(1-n\),询问插入哪一张牌后,可以使牌由一个对子(\(2\)张相同牌).\ ...

  3. BZOJ刷题记录---提高组难度

    BZOJ刷题记录---提高组难度 总目录详见https://blog.csdn.net/mrcrack/article/details/90228694 序号 题号 算法 思想难度 实现难度 总难度 ...

  4. OI 刷题记录——每周更新

    每周日更新 2016.05.29 UVa中国麻将(Chinese Mahjong,Uva 11210) UVa新汉诺塔问题(A Different Task,Uva 10795) NOIP2012同余 ...

  5. 2019.3.summary

    emmmm,把以前写的2b总结丢上来吧,不过应该也不会有人看QAQ (注:因为用txt写的,有一些公式打的很随意,放到markdown上公式自动排版,有可能会显示出错误!可在下方留言) 2019.2. ...

  6. TW特别策划:网络视频麻将局,谁会最先胡【详细】

    据 相关数据显示2008年上半年,视频分享已经跻身主流媒介,成为中国网民上网重要去处.且视频网站的前两名已占据了视频分享市场有效浏览时间78.3%的 市场份额.视频分享市场垄断局面已经成型的同时使得竞 ...

  7. 微软麻将AI Suphx或引入“凤凰房”,与其他AI对打

    作者 | 夕颜 出品 | AI科技大本营(ID:rgznai100) [导读]在刚刚结束的上海2019世界人工智能大会上,微软宣布了其在人工智能领域的最新研究突破--由微软亚洲研究院研发的麻将 AI ...

  8. 超越99.9%人类玩家,微软专业十段麻将AI论文细节首次公布

      视学算法分享   转自 | 机器之心 [导读]在去年 8 月底的世界人工智能大会上,时任微软全球执行副总裁的沈向洋正式对外宣布了微软亚洲研究院研发的麻将 AI「Suphx 」.近日,关于 Suph ...

  9. node.js——麻将算法(六)简易版麻将出牌AI1.0

    普通麻将的出牌AI如果不是要求特别高的话,其实蛮容易实现的,毕竟大多数人打牌都只是看自己的手牌. 所以作为简易版的AI,出牌的策略只要奔着胡牌去就可以了.我们能想到的就是把相邻或相同的牌凑到一起,把单 ...

最新文章

  1. 数据库将某个字段由可为空改为非空
  2. gdi画平滑直线_石膏几何体不会画?那是你没有画过这些,学会画石膏很简单,收藏...
  3. tortoisegit图标消失_TortoiseGit文件夹和文件图标不显示解决方法
  4. MySQL高可用架构对比
  5. python查找文件内容_python实现搜索文本文件内容脚本
  6. linux mysql 主从数据库_Linux下安装MySQL及MySQL主从同步配置
  7. #SQL1242错误
  8. Excel工作表保护在哪里撤销?
  9. 诺瓦面试(一面和二面)总结
  10. Matlab入门:实现简单的数据剔除
  11. 多智能体强化学习- COMA
  12. 年终总结--时光如水,生命如歌
  13. 7.6-7.13牟尼沟、若尔盖旅游日记
  14. 对“动态多重网络”建模与目标选择方法的介绍
  15. html背景视频模糊效果,怎么给竖屏视频添加模糊背景的效果
  16. 35.在layer上画文字 画图片
  17. 【Pycharm教程】PyCharm 安装、卸载和升级包
  18. 林大锐格-算法-6121
  19. 关于C语言实现凯撒加密算法
  20. 第一章:操作系统概论

热门文章

  1. 1.7 编程基础之字符串 16 忽略大小写的字符串比较 python
  2. react 访问后端_react前端用nginx怎么配置跨域访问后端restful api?
  3. Linux|Qt工作笔记-linux系统下安装qt4.5.3版本的详细步骤
  4. Linux工作笔记-CentOS 调整 home分区 扩大 root分区
  5. vue学生作业-图书管理系统
  6. Hyper-v和VMware 兼容问题
  7. mysql10038_navicat for mysql (10038)如何解决
  8. java开发引擎_【java规则引擎】java规则引擎搭建开发环境
  9. python xlrd安装_详解python中xlrd包的安装与处理Excel表格
  10. hashcat 基本使用