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

    思路:

    就是道普通模拟题
    1、考虑新开局0:0 2、比分差>=2才结束(没理解被坑了) 即如果比分为11:10比赛是不能结束的,还要继续比,同理17:16;直到如18:16结束

    题目描述

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

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

    WWWWWWWWWWWWWWWWWWWWWWLW

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

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

    输入格式

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

    输出格式

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

     1 #include<stdio.h> 
     2 #include<string.h>
     3 
     4 
     5 
     6 int main()
     7 {
     8 //    freopen("r.txt","r",stdin);
     9     
    10     char c;
    11 
    12     int n1=0,n2=0,w=0,l=0,w2=0,l2=0,num=0;
    13     bool r = 0,r2 = 0;
    14     int sec[10000][2];
    15     do{
    16         c = getchar();
    17         if(c=='L'||c=='W')
    18         {
    19             if(c=='W')
    20             {
    21                 w++;
    22                 w2++;
    23                 if(w%11==0)    
    24                 r = 1;
    25                 if(w2%21==0)
    26                 r2 = 1;
    27             }
    28             else
    29             {
    30                 l++;
    31                 l2++;
    32                 if(l%11==0)
    33                 r = 1;
    34                 if(l2%21==0)
    35                 r2 = 1;
    36             }
    37         }
    38         
    39         if(r&&((w-l)>=2||(l-w)>=2))
    40         {
    41             printf("%d:%d
    ",w,l);
    42             w=0;l=0;r=0;n1=0;
    43 
    44         }
    45         if(r2&&((w2-l2)>=2||(l2-w2)>=2))
    46         {
    47             sec[num][0]=w2;
    48             sec[num][1]=l2;
    49             w2=0;l2=0;r2=0;
    50             num++;n2=0;
    51         }    
    52     }while(c!='E');
    53 
    54     printf("%d:%d
    ",w,l);
    55     printf("
    ");
    56 
    57         for(int i=0;i<num;i++)
    58         {
    59             printf("%d:%d
    ",sec[i][0],sec[i][1]);
    60         }
    61     
    62     printf("%d:%d",w2,l2);
    63     
    64     freopen("w.txt","w",stdout); //程序输出的内容保存在此文件里
    65 }
  • 相关阅读:
    IM服务器架构实现
    TCP打洞技术
    Java的守护线程与非守护线程
    SQL中时间为空的处理小结
    tfs
    Silverlight技术总结
    PMS
    Silverlight的TabControl的selectionChanged事件中读取不到TextBox值的bug。
    hahahahahah
    APM文章
  • 原文地址:https://www.cnblogs.com/Theo-sblogs/p/12865969.html
Copyright © 2011-2022 走看看