Description

lyd学会了使用扑克DIY占卜。方法如下:一副去掉大小王的扑克共52张,打乱后均分为13堆,编号1~13,每堆4张,其中第13堆称作“生命牌”,也就是说你有4条命。这里边,4张K被称作死神。
初始状态下,所有的牌背面朝上扣下。
流程如下:
1.抽取生命牌中的最上面一张(第一张)。
2.把这张牌翻开,正面朝上,放到牌上的数字所对应编号的堆的最上边。(例如抽到2,正面朝上放到第2堆牌最上面,又比如抽到J,放到第11堆牌最上边,注意是正面朝上放)
3.从刚放了牌的那一堆最底下(最后一张)抽取一张牌,重复第2步。(例如你上次抽了2,放到了第二堆顶部,现在抽第二堆最后一张发现是8,又放到第8堆顶部.........)

4.在抽牌过程中如果抽到K,则称死了一条命,就扔掉K再从第1步开始。
5.当发现四条命都死了以后,统计现在每堆牌上边正面朝上的牌的数目,只要同一数字的牌出现4张正面朝上的牌(比如4个A),则称“开了一对”,当然4个K是不算的。
6.统计一共开了多少对,开了0对称作"极凶",1~2对为“大凶”,3对为“凶”,4~5对为“小凶”,6对为“中庸”,7~8对“小吉”,9对为“吉”,10~11为“大吉”,12为“满堂开花,极吉”。

如果还不明白,就去看样例把。。。

Input

一共13行,为每堆牌的具体牌是什么(不区分花色只区分数字),每堆输入的顺序为从上到下。
为了便于读入,用0代表10,那么A,J,Q,K(大写)就不用说了吧。。。

Output

一共开了几对。

Sample Input

8 5 A A
K 5 3 2
9 6 0 6
3 4 3 4
3 4 4 5
5 6 7 6
8 7 7 7
9 9 8 8
9 0 0 0
K J J J
Q A Q K
J Q 2 2
A K Q 2

Sample Output

9

元宵节待在机房刷题,看到难点的就不想写;

那么就来水道模拟题玩玩

大佬点的人可以选择用链表模拟

我本来就懒,这题范围也就这么点,暴力搞搞就好了

代码(长度可以优化,懒得改了,反正都AC了)

 #include<cstdio>
int s[][],f[],ans;
char a,b,c,d;
int main()
{
for(int i=;i<=;i++)
{
scanf("%c %c %c %c\n",&a,&b,&c,&d);
if(a>''&&a<='')s[i][]=a-'';
if(b>''&&b<='')s[i][]=b-'';
if(c>''&&c<='')s[i][]=c-'';
if(d>''&&d<='')s[i][]=d-'';
if(a=='A')s[i][]=;
if(b=='A')s[i][]=;
if(c=='A')s[i][]=;
if(d=='A')s[i][]=;
if(a=='J')s[i][]=;
if(b=='J')s[i][]=;
if(c=='J')s[i][]=;
if(d=='J')s[i][]=;
if(a=='Q')s[i][]=;
if(b=='Q')s[i][]=;
if(c=='Q')s[i][]=;
if(d=='Q')s[i][]=;
if(a=='K')s[i][]=;
if(b=='K')s[i][]=;
if(c=='K')s[i][]=;
if(d=='K')s[i][]=;
if(a=='')s[i][]=;
if(b=='')s[i][]=;
if(c=='')s[i][]=;
if(d=='')s[i][]=;
}
scanf("%c %c %c %c",&a,&b,&c,&d);
if(a>''&&a<='')s[][]=a-'';
if(b>''&&b<='')s[][]=b-'';
if(c>''&&c<='')s[][]=c-'';
if(d>''&&d<='')s[][]=d-'';
if(a=='A')s[][]=;
if(b=='A')s[][]=;
if(c=='A')s[][]=;
if(d=='A')s[][]=;
if(a=='J')s[][]=;
if(b=='J')s[][]=;
if(c=='J')s[][]=;
if(d=='J')s[][]=;
if(a=='Q')s[][]=;
if(b=='Q')s[][]=;
if(c=='Q')s[][]=;
if(d=='Q')s[][]=;
if(a=='K')s[][]=;
if(b=='K')s[][]=;
if(c=='K')s[][]=;
if(d=='K')s[][]=;
if(a=='')s[][]=;
if(b=='')s[][]=;
if(c=='')s[][]=;
if(d=='')s[][]=;
while()
{
if(f[]==)break;
int now=s[][];
f[now]++;
for(int i=;i<=;i++)s[][i-]=s[][i];
if(now==)continue;
while()
{
for(int i=;i>=;i--)s[now][i+]=s[now][i];
s[now][]=now;
now=s[now][];
f[now]++;
if(now==)break;
}
}
for(int i=;i<=;i++)if(f[i]==)ans++;
printf("%d",ans);
}

最新文章

  1. 在QtCreator中使用doxygen
  2. 20160712001 SQL server R2 更名
  3. Android之ListView——ArrayAdapter的用法学习
  4. &lt;meta&gt;元素
  5. html5 音频
  6. properties + IO 读取配置文件
  7. hdu_5776_sum(前缀和维护)
  8. 篇3 安卓app自动化测试-搞定界面元素
  9. Django 框架介绍
  10. Servlet--创建和配置Servlet
  11. Caused by: com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure
  12. 求n!中含有某个因子个数的方法
  13. vue echarts 动态数据
  14. 【cf789B】Masha and geometric depression(分类讨论/暴力)
  15. 理解JS的执行环境
  16. 学了这么久,vue和微信小程序到底有什么样的区别?
  17. HDU 5143 NPY and arithmetic progression(思维)
  18. DevExpress03、GridControl
  19. 国际化实现之安装脚手架vue以及打包问题
  20. Django-url路由映射与views逻辑处理

热门文章

  1. java中Integer在JDK1.6和JDK1.7中的区别
  2. mysql错误指令:Failed to open file &quot;file_name&quot; error 2/error 22
  3. const与define应用上该怎么取舍
  4. 微信 jssdk 逻辑在 vue 中的运用
  5. Codeforces696 Round #362 (Div. 1)(vp) A~D题解
  6. 多线程设计模式(一) Single Threaded Execution
  7. golang 关于golang.org/x包问题
  8. awk实现求和、平均、最大值和最小值的计算操作
  9. bzoj2750Road——最短路计数
  10. 增加,删除GMS包