Vijos p1217 兵乓球

Posted yachen2018

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Vijos p1217 兵乓球相关的知识,希望对你有一定的参考价值。

描述
华华通过以下方式进行分析,首先将比赛每个球的胜负列成一张表,然后分别计算在11分制和21分制下,双方的比赛结果(截至记录末尾)。
比赛规则和实际比赛规则相同, 在11分制下比分为10:11时还要继续比赛,直到分数差距达到2分;同理21分制下比分为20:21的时候也还要继续比赛。
比如现在有这么一份记录,(其中W表示华华获得一分,L表示华华对手获得一分):
WWWWWWWWWWWWWWWWWWWWWWLW
在11分制下,此时比赛的结果是华华第一局11比0获胜,第二局11比0获胜,正在进行第三局,当前比分1比1。而在21分制下,此时比赛结果是华华第一局21比0获胜,正在进行第二局,比分2比1。如果一局比赛刚开始,则此时比分为0比0。
你的程序就是要对于一系列比赛信息的输入(WL形式),输出正确的结果。

输入格式
每个输入文件包含若干行字符串(每行至多20个字母),字符串有大写的W、L和E组成,也许中间有若干个空格。其中E表示比赛信息结束,程序应该忽略E之后的所有内容,E后面可能有干扰文字。

输出格式
输出由两部分组成,每部分有若干行,每一行对应一局比赛的比分(按比赛信息输入顺序)。其中第一部分是11分制下的结果,第二部分是21分制下的结果,两部分之间由一个空行分隔。
样例1

样例输入1
WWWWWWWWWWWWWWWWWWWW
WWLWE


样例输出1
11:0
11:0
1:1

21:0
2:1

限制
各个测试点1s

提示
十分简单,小心输入输出格式!^_^

 

 

思路

模拟,注意0:0也要输出

 

代码

 1 #include <stdio.h>
 2 #include <stdlib.h>
 3 #include <string.h>
 4 
 5 int main() {
 6     int a11,b11,a21,b21;
 7     char s11[1000000],s21[1000000],tmp[10000];
 8     char c;
 9     memset (s11,0,sizeof(s11));
10     memset (s21,0,sizeof(s21));
11     memset (tmp,0,sizeof(tmp));
12     a11 = 0;
13     b11 = 0;
14     a21 = 0;
15     b21 = 0;
16     while ((c=getchar()))    {
17         if (c==E) {
18             sprintf (tmp,"%d:%d\n",a11,b11);
19             strcat (s11,tmp);
20             sprintf (tmp,"%d:%d\n",a21,b21);
21             strcat (s21,tmp);
22             break;    
23         }
24         if (c==W) {
25             a11++;
26             a21++;
27             if (a11>=11 && a11-b11>1) {
28                 sprintf (tmp,"%d:%d\n",a11,b11);
29                 strcat (s11,tmp);
30                 a11=0;
31                 b11=0;
32             }
33             if (a21>=21 && a21-b21>1) {
34                 sprintf (tmp,"%d:%d\n",a21,b21);
35                 strcat (s21,tmp);
36                 a21=0;
37                 b21=0;
38             }
39         }
40         if (c==L) {
41             b11++;
42             b21++;
43             if (b11>=11 && b11-a11>1) {
44                 sprintf (tmp,"%d:%d\n",a11,b11);
45                 strcat (s11,tmp);
46                 a11=0;
47                 b11=0;
48             }
49             if (b21>=21 && b21-a21>1) {
50                 sprintf (tmp,"%d:%d\n",a21,b21);
51                 strcat (s21,tmp);
52                 a21=0;
53                 b21=0;
54             }                
55         }
56     }
57     printf ("%s\n",s11);
58     printf ("%s",s21);
59     system("pause");
60     return 0;
61 }

 

以上是关于Vijos p1217 兵乓球的主要内容,如果未能解决你的问题,请参考以下文章

下一个兵乓球冠军就是你:VR联机游戏《Paddle Up》

p1217 乒乓球

栈和队列

拓扑排序

练习二十二:python兵乓求比赛顺序练习,关于连个兵乓球队进行比赛

兵乓操作的3个作用