1443•乒乓球 解题报告

该博客介绍了一种模拟乒乓球比赛的方法,根据11分制和21分制的规则计算比赛结果。通过输入比赛记录(W表示华华得分,L表示对手得分),程序能够输出每局比赛的比分。博客提供了算法思路,包括使用数组存储比分,判断比赛结束条件,并给出了完整的C++代码实现。
摘要由CSDN通过智能技术生成

题目描述

       国际乒联现在主席沙拉拉自从上任以来就立志于推行一系列改革,以推动乒乓球运动在全球的普及。其中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之后的所有内容。
每行至多25个字母,最多有2500行。

输出

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

输入样例 复制

WWWWWWWWWWWWWWWWWWWW
WWLWE

输出样例 复制

11:0
11:0
1:1

21:0
2:1

此题其实并不复杂......

思路如下:判断每球的胜负,存数组后输出

定义:

gs1:11分制的指标

gs2:21分制的指标

x1[100010]:储存11分制下华华比分

x2[100010]:储存21分制下华华比分

yy1[100010]:储存11分制下对手比分

yy2[100010]:储存21分制下对手比分

正文:

cin>>n;

while (n!='E')//n为E则结束

{

    if (n=='W')

    {

     x1[gs1]++;x2[gs2]++;//华华加分(两种分制都储存)

     if (x1[gs1]>10//要>=11分&&x1[gs1]-yy1[gs1]>=2//且分差要>=2分) gs1++;//说明此局结束,进入下一个0:0开始的数组

if (x2[gs2]>20&&x2[gs2]-yy2[gs2]>=2) gs2++;//思路同上

   }

   else //思路与前文一致,故不多做解释

    {

     yy1[gs1]++;yy2[gs2]++;

     if (yy1[gs1]>10&&yy1[gs1]-x1[gs1]>=2) gs1++;

if (yy2[gs2]>20&&yy2[gs2]-x2[gs2]>=2) gs2++;

    }

    cin>>n;

     }

     for (long long i=0;i<=gs1;i++) cout<<x1[i]<<":"<<yy1[i]<<endl;//把比分输出即可

     cout<<endl;

     for (long long i=0;i<=gs2;i++) cout<<x2[i]<<":"<<yy2[i]<<endl;

}

寄语:最后提醒大家,复制有害健康,请勿copy

#include<bits/stdc++.h> 
using namespace std;
char str[1000001]; 
char a;
int cnt=0;
void ccl(int n){
    int a=0,b=0;
    for(int i=1;i<=cnt;i++){
        if(str[i]=='W'){
            a++;
        }if(str[i]=='L'){
            b++;
        }if((a>=n||b>=n)&&abs(a-b)>=2){
            cout<<a<<":"<<b<<endl;
            a=b=0;
        }
    }cout<<a<<":"<<b<<endl;
    return;
}
int main(){
    while(cin>>a&&a!='E'){
        if(a=='W'||a=='L'){
            cnt++; 
            str[cnt]=a;
        }
    }ccl(11);
    cout<<endl;
    ccl(21);
    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值