• 洛谷 P1042 乒乓球


    链接:https://www.luogu.org/problemnew/show/P1042

    题目:

      题目背景

      国际乒联现在主席沙拉拉自从上任以来就立志于推行一系列改革,以推动乒乓球运动在全球的普及。其中1111分制改革引起了很大的争议,有一部分球员因为无法适应新规则只能选择退役。华华就是其中一位,他退役之后走上了乒乓球研究工作,意图弄明白1111分制和2121分制对选手的不同影响。在开展他的研究之前,他首先需要对他多年比赛的统计数据进行一些分析,所以需要你的帮忙。

      题目描述

      华华通过以下方式进行分析,首先将比赛每个球的胜负列成一张表,然后分别计算在1111分制和2121分制下,双方的比赛结果(截至记录末尾)。

      比如现在有这么一份记录,(其中W表示华华获得一分,L表示华华对手获得一分):

      WWWWWWWWWWWWWWWWWWWWWWLW

      在1111分制下,此时比赛的结果是华华第一局1111比00获胜,第二局1111比00获胜,正在进行第三局,当前比分11比11。而在2121分制下,此时比赛结果是华华第一局2121比00获胜,正在进行第二局,比分22比11。如果一局比赛刚开始,则此时比分为00比00。直到分差大于或者等于22,才一局结束。

      你的程序就是要对于一系列比赛信息的输入(WLWL形式),输出正确的结果。

      输入输出格式

      输入格式:

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

      输出格式:

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

      输入输出样例

      输入样例#1: 
      WWWWWWWWWWWWWWWWWWWW
      WWLWE
    
      输出样例#1: 
      11:0
      11:0
      1:1
    
      21:0
      2:1
    

      说明

      每行至多25个字母,最多有2500行

    思路:

      不是很难,读取输入,统计数据,直接输出,只要记得到E结束,char范围给大一点,考虑到0:0的情况就行。

    代码:

     1 #include<iostream>
     2 #include<cstring>
     3 #include<cmath>
     4 #include<cstdio>
     5 using namespace std;
     6 
     7 int main()
     8 {
     9     char a[2600];
    10     int ans = 0;
    11     while(true)
    12     {
    13         char c = getchar();
    14         if(c=='W'||c=='L')
    15         {
    16             a[ans]=c;
    17             ans++;
    18         }
    19         if(c=='E')
    20             break;
    21     }
    22     int w=0;
    23     int l=0;
    24     for(int i=0;i<ans;i++)
    25     {
    26         if(a[i]=='W')
    27             w++;
    28         if(a[i]=='L')
    29             l++;
    30         if((w>=11||l>=11)&&(abs(w-l)>=2))
    31         {
    32             cout<<w<<":"<<l<<endl;
    33             w=0;
    34             l=0;
    35         }
    36         else if(i==ans-1)
    37             cout<<w<<":"<<l<<endl;
    38     }
    39     if(w==0&&l==0)
    40         cout<<w<<":"<<l<<endl;
    41     cout<<endl;
    42     w=0;
    43     l=0;
    44     for(int i=0;i<ans;i++)
    45     {
    46         if(a[i]=='W')
    47             w++;
    48         if(a[i]=='L')
    49             l++;
    50         if((w>=21||l>=21)&&abs(w-l)>=2)
    51         {
    52             cout<<w<<":"<<l<<endl;
    53             w=0;
    54             l=0;
    55         }
    56         else if(i==ans-1)
    57             cout<<w<<":"<<l<<endl;
    58     }
    59     if(w==0&&l==0)
    60         cout<<w<<":"<<l<<endl;
    61     return 0;
    62 } 
  • 相关阅读:
    C#中泛型类,泛型方法,泛型约束实际应用
    Sql语法高级应用之七:如何在存储过程中使用事务
    再探motan
    终于好像懂motan了!!!
    java 反射详解
    设计模式之一工厂方法模式(Factory Method)
    记一次CPU占用率和load高的排查
    浅谈反射性能
    短网址服务(TinyURL)生成算法
    记一次阿里云中间件面试
  • 原文地址:https://www.cnblogs.com/blogxjc/p/11187102.html
Copyright © 2020-2023  润新知