zoukankan      html  css  js  c++  java
  • 乒乓球

    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 }
  • 相关阅读:
    POJ 1401 Factorial
    POJ 2407 Relatives(欧拉函数)
    POJ 1730 Perfect Pth Powers(唯一分解定理)
    POJ 2262 Goldbach's Conjecture(Eratosthenes筛法)
    POJ 2551 Ones
    POJ 1163 The Triangle
    POJ 3356 AGTC
    POJ 2192 Zipper
    POJ 1080 Human Gene Functions
    POJ 1159 Palindrome(最长公共子序列)
  • 原文地址:https://www.cnblogs.com/yewanting/p/10538673.html
Copyright © 2011-2022 走看看