p1217 乒乓球

Posted archemiya

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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

思路
这题没啥思路,从纯c的角度看考察字符数组的使用问题,需要注意数组的大小。

代码

 1 #include <stdio.h>
 2 #include <stdlib.h>
 3 
 4 int main(){
 5     char info[100000];
 6     info[0]=0;
 7     int j,i=0,a=0,b=0;
 8     do{
 9         scanf("%c",&info[i]);
10     }while(info[i++]!=E);
11     for(j=0;j<i-1;j++){
12         if(info[j]==W){
13             a++;
14         }
15         if(info[j]==L){
16             b++;
17         }
18         if(info[j]==\n){
19             continue;
20         }
21         if((a==11||b==11)&&abs(a-b)>=2){
22             printf("%d:%d\n",a,b);
23             a=0;
24             b=0;
25         }
26         if(a>=10&&b>=10){
27             while(abs(a-b)>=2){
28                 printf("%d:%d\n",a,b);
29                 a=0;
30                 b=0;
31             }
32         }
33     }
34     printf("%d:%d\n",a,b);
35     a=0;
36     b=0;
37     printf("\n");
38     for(j=0;j<i-1;j++){
39         if(info[j]==W){
40             a++;
41         }
42         if(info[j]==L){
43             b++;
44         }
45         if(info[j]==\n){
46             continue;
47         }
48         if((a==21||b==21)&&abs(a-b)>=2){
49             printf("%d:%d\n",a,b);
50             a=0;
51             b=0;
52         }
53         if(a>=20&&b>=20){
54             while(abs(a-b)>=2){
55             printf("%d:%d\n",a,b);
56             a=0;
57             b=0;
58             }
59         }
60     }
61     printf("%d:%d",a,b);
62     return 0;
63 }

 

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

Vijos p1217 兵乓球

题解 P1217 [USACO1.5]回文质数 Prime Palindromes

题解 P1217 [USACO1.5]回文质数 Prime Palindromes

两个乒乓球队进行比赛,各出三人。甲队为a,b,c三人,乙队为x,y,z三人。 已抽签决定比赛名单。有人向队员打听比赛的名单。 a说他不和x比,c说他不和x,z比,请编程序找出三队赛手的名单。(代码片段

洛谷P1217回文质数-Prime Palindrome回溯

洛谷 P1217 [USACO1.5]回文质数 Prime Palindromes