• 乒乓球


    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 }
  • 相关阅读:
    限制TextBox框 所输入的字符数
    ASP.NET中使用AJAX后,Session丢失异常的自定义处理。
    用div替代模态窗口
    自动更新程序的制作方法
    常用SQL语句集合
    GridView无数据显示表头类
    密码强度
    GridView绑定技巧终结者
    js验证输入是否为手机号码或电话号码
    Js事件列表
  • 原文地址:https://www.cnblogs.com/yewanting/p/10538673.html
Copyright © 2020-2023  润新知