乒乓球

Description

国际乒联现在主席沙拉拉自从上任以来就立志于推行一系列改革,以推动乒乓球运动在全球的普及。其中11分制改革引起了很大的争议,有一部分球员因为无法适应新规则只能选择退役。华华就是其中一位,他退役之后走上了乒乓球研究工作,意图弄明白11分制和21分制对选手的不同影响。在开展他的研究之前,他首先需要对他多年比赛的统计数据进行一些分析,所以需要你的帮忙。
华华通过以下方式进行分析,首先将比赛每个球的胜负列成一张表,然后分别计算在11分制和21分制下,双方的比赛结果(截至记录末尾)。
比如现在有这么一份记录,(其中W表示华华获得一分,L表示华华对手获得一分):
WWWWWWWWWWWWWWWWWWWWWWLW
在11分制下,此时比赛的结果是华华第一局11比0获胜,第二局11比0获胜,正在进行第三局,当前比分1比1。而在21分制下,此时比赛结果是华华第一局21比0获胜,正在进行第二局,比分2比1。如果一局比赛刚开始,则此时比分为0比0。
你的程序就是要对于一系列比赛信息的输入(WL形式),输出正确的结果。
注意!11分制,假设最后10:10,是要12:10才算赢得!!21分制同理!
注意!11分制,假设最后10:10,是要12:10才算赢得!!21分制同理!

Input

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

Output

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

Sample Input 1

 WWWWWWWWWWWWWWWWWWWW

WWLWE
Sample Output 1
11:0
11:0
1:1

21:0
2:1
 
 
解题思路:这道题主要是题意难懂,看了半天也不知道它要表达什么,以为它是一行代表一局,一行一行的算,但是怎么也算不出输出的结果;
正确理解:(1)输入的几行连接起来,11分制就是看对方谁先达到11分,且两者差值要>=2;21分制就是谁先达到21分,且两者差值>=2;则输出一局的结果。
(2)注意如果遇到E,且还没达到11或21,则就直接输出剩下的比分;
(3)注意条件要写清楚,要写成((w>=11&&(w-l)>=2)||l>=11&&(l-w)>=2)与(w>=21&&(w-l)>=2)||l>=21&&(l-w)>=2)
如果写成(w>=11||l>=11&&abs(w-l)>=2) 与(w>=21||l>=21&&abs(w-l)>=2)
提交上去会一直wrong answer  ,而且还不知道自己到底错了
代码如下:
 1 #include<iostream>
 2 #include<cmath>
 3 using namespace std;
 4 
 5 string s;
 6 string tmp;
 7 long long int count1;
 8 int main()
 9 {
10     int w = 0 , l = 0;
11     while(cin>>s)
12     {
13         tmp += s;    //将输入的所有行加在一起,变成一行的字符串;
14     }
15     
16 
17     count1 = tmp.size();    //或者字符串总长度
18 
19     
20     for(int i = 0 ; i < count1;i++)
21     {
22         if(tmp[i]=='E') break;    //如果遇到E,则退出循环;  
23         if(tmp[i]=='W') w++;      //统计W的个数;
24         if(tmp[i]=='L') l++;      //统计L的个数;
25         if((w>=11&&(w-l)>=2)||l>=11&&(l-w)>=2)  //按照题意要求的11分制;
26         {
27             cout<<w<<":"<<l<<endl;     
28             w = 0;        //注意将w,l重新置为0,再统计,因为这是新的一局了;
29             l = 0;
30         }
31         
32     }
33     cout<<w<<":"<<l<<endl;    //遇到E,跳出循环,且还没达到11,则就直接输出剩下的比分;
34     cout<<endl;
35      w = 0, l = 0;    //注意将w,l重新置为0,再统计,因为这是新的一局了;   
36 for(int i = 0 ; i < count1;i++) 37 { 38 if(tmp[i]=='E') break; //如果遇到E,则退出循环;  39 if(tmp[i]=='W') w++; //统计W的个数; 40 if(tmp[i]=='L') l++; //统计L的个数; 41 if((w>=21&&(w-l)>=2)||l>=21&&(l-w)>=2) //按照题意要求的21分制; 42 { 43 cout<<w<<":"<<l<<endl; 44 w = 0; //注意将w,l重新置为0,再统计,因为这是新的一局了; 45 l = 0; 46 47 } 48 } 49 cout<<w<<":"<<l<<endl;   //遇到E,跳出循环,且还没达到11,则就直接输出剩下的比分; 50 return 0; 51 }
原文地址:https://www.cnblogs.com/yewanting/p/10538673.html