题目背景
国际乒联现在主席沙拉拉自从上任以来就立志于推行一系列改革,以推动乒乓球运动在全球的普及。其中1111分制改革引起了很大的争议,有一部分球员因为无法适应新规则只能选择退役。华华就是其中一位,他退役之后走上了乒乓球研究工作,意图弄明白11分制和21分制对选手的不同影响。在开展他的研究之前,他首先需要对他多年比赛的统计数据进行一些分析,所以需要你的帮忙。
题目描述
华华通过以下方式进行分析,首先将比赛每个球的胜负列成一张表,然后分别计算在11分制和21分制下,双方的比赛结果(截至记录末尾)。
比如现在有这么一份记录,(其中W
表示华华获得一分,L
表示华华对手获得一分):
WWWWWWWWWWWWWWWWWWWWWWLW
在11分制下,此时比赛的结果是华华第一局11比0获胜,第二局11比0获胜,正在进行第三局,当前比分1比1。而在21分制下,此时比赛结果是华华第一局21比0获胜,正在进行第二局,比分2比1。如果一局比赛刚开始,则此时比分为0比0。直到分差大于或者等于2,才一局结束。
你的程序就是要对于一系列比赛信息的输入(WL形式),输出正确的结果。
输入输出格式
输入格式:
每个输入文件包含若干行字符串,字符串有大写的W、L和E组成。其中E表示比赛信息结束,程序应该忽略E之后的所有内容。
输出格式:
输出由两部分组成,每部分有若干行,每一行对应一局比赛的比分(按比赛信息输入顺序)。其中第一部分是11分制下的结果,第二部分是21分制下的结果,两部分之间由一个空行分隔。
输入输出样例
输入样例#1: 复制
WWWWWWWWWWWWWWWWWWWW
WWLWE
输出样例#1: 复制
11:0
11:0
1:1
21:0
2:1
说明
每行至多25个字母,最多有2500行
水题。一局结束的条件是一方有11或21分以上并且与另一方的分差大于等于2.
AC代码:
1 #include<iostream> 2 #include<sstream> 3 #include<algorithm> 4 #include<string> 5 #include<cstring> 6 #include<iomanip> 7 #include<vector> 8 #include<cmath> 9 #include<ctime> 10 #include<stack> 11 #include<queue> 12 #include<map> 13 #define e 2.71828182 14 #define Pi 3.141592654 15 using namespace std; 16 int main() 17 { 18 int score_11[2][5690],score_21[2][3000],count1=1,count2=1; 19 char ch; 20 memset(score_11,0,sizeof(score_11)); 21 memset(score_21,0,sizeof(score_21)); 22 while(cin>>ch&&ch!='E') 23 { 24 if(ch=='W') score_11[0][count1]++,score_21[0][count2]++; 25 else if(ch=='L') score_11[1][count1]++,score_21[1][count2]++; 26 if((score_11[0][count1]>=11&&score_11[0][count1]>=score_11[1][count1]+2)|| 27 (score_11[1][count1]>=11&&score_11[1][count1]>=score_11[0][count1]+2)) 28 count1++; 29 if((score_21[0][count2]>=21&&score_21[0][count2]>=score_21[1][count2]+2)|| 30 (score_21[1][count2]>=21&&score_21[1][count2]>=score_21[0][count2]+2)) 31 count2++; 32 } 33 for(int i=1;i<=count1;i++) 34 cout<<score_11[0][i]<<':'<<score_11[1][i]<<endl; 35 cout<<endl; 36 for(int i=1;i<=count2;i++) 37 cout<<score_21[0][i]<<':'<<score_21[1][i]<<endl; 38 } 39