• Luogu 1042


    题目链接:https://www.luogu.org/problemnew/show/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形式),输出正确的结果。

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

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

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

    21:0
    2:1
    说明
    每行至多25个字母,最多有2500行

    AC代码:

    #include<bits/stdc++.h>
    using namespace std;
    string str;
    int w,l;
    int main()
    {
        string tmp;
        bool haveE=0;
        while(cin>>tmp)
        {
            for(int i=0;i<tmp.size();i++)
            {
                if(tmp[i]=='E') {haveE=1; break;}
                else str+=tmp[i];
            }
            if(haveE) break;
        }
    
        //11分制
        w=l=0;
        for(int i=0;i<str.size();i++)
        {
            if(str[i]=='W') w++;
            if(str[i]=='L') l++;
            if((w>=11 || l>=11) && abs(w-l)>=2)
            {
                printf("%d:%d
    ",w,l);
                w=l=0;
            }
        }
        printf("%d:%d
    
    ",w,l);
    
        //21分制
        w=l=0;
        for(int i=0;i<str.size();i++)
        {
            if(str[i]=='W') w++;
            if(str[i]=='L') l++;
            if((w>=21 || l>=21)  && abs(w-l)>=2)
            {
                printf("%d:%d
    ",w,l);
                w=l=0;
            }
        }
        printf("%d:%d
    ",w,l);
    }
  • 相关阅读:
    Compression algorithm (deflate)
    tcpip数据包编码解析(chunk and gzip)_space of Jialy_百度空间
    What's the difference between the "gzip" and "deflate" HTTP 1.1 encodings?
    gzip压缩算法: gzip 所使用压缩算法的基本原理
    Decompressing a GZip Stream with Zlib
    Frequently Asked Questions about zlib
    how to decompress gzip stream with zlib
    自己动手写web服务器四(web服务器是如何通过压缩数据,web服务器的gzip模块的实现)
    What's the difference between the "gzip" and "deflate" HTTP 1.1 encodings?
    C语言抓http gzip包并解压 失败 C/C++ ChinaUnix.net
  • 原文地址:https://www.cnblogs.com/dilthey/p/10236021.html
Copyright © 2020-2023  润新知