zoukankan      html  css  js  c++  java
  • 洛谷 P1042 乒乓球

    题目背景

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

    题目描述

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

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

    WWWWWWWWWWWWWWWWWWWWWWLW

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

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

    输入输出格式

    输入格式:

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

    输出格式:

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

    输入输出样例

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

     1 #include<iostream>
     2 #include<cstdio>
     3 #include<string>
     4 #include<cstring>
     5 #include<algorithm>
     6 #include<cmath>
     7 
     8 using namespace std;
     9 
    10 char wl[100000001];
    11 
    12 int main()
    13  {
    14     int k=0;
    15     int ww=0;
    16     int ll=0;
    17     for(int i=1;; i++) 
    18     {
    19         cin>>wl[i];
    20         k++;
    21         if(wl[i]=='E') 
    22             break;
    23     }
    24     for(int i=1; i<=k; i++) 
    25     {
    26         if(wl[i]=='W')
    27             ww++;
    28         if(wl[i]=='L') 
    29             ll++;
    30         if((ww>=11||ll>=11)&&(abs(ww-ll)>=2)) 
    31         {
    32             printf("%d:%d
    ",ww,ll);
    33             ww=0;
    34             ll=0;
    35         }
    36         if(wl[i]=='E') 
    37         {
    38             printf("%d:%d
    ",ww,ll);
    39             ww=0;
    40             ll=0;
    41             cout<<endl;
    42         }
    43     }
    44     for(int i=1; i<=k; i++) 
    45     {
    46         if(wl[i]=='W') 
    47             ww++;
    48         if(wl[i]=='L') 
    49             ll++;
    50         if((ww>=21||ll>=21)&&(abs(ww-ll)>=2)) 
    51         {
    52             printf("%d:%d
    ",ww,ll);
    53             ww=0;
    54             ll=0;
    55         }
    56         if(wl[i]=='E') 
    57             printf("%d:%d
    ",ww,ll);
    58     }
    59     return 0;
    60 }
  • 相关阅读:
    进程同步和死锁;事务、悲观锁、乐观锁、表锁、行锁
    快速排序
    oracle索引分类
    数据结构
    MySQL视图
    sql优化的方法
    MySQL索引
    转:关于ROWNUM的使用
    转载:mybatis踩坑之——foreach循环嵌套if判断
    Spring 注意事项
  • 原文地址:https://www.cnblogs.com/lyqlyq/p/6875144.html
Copyright © 2011-2022 走看看