【字符串】POJ1271乒乓球

时间:2022-12-16 19:29:31

题目链接:https://vijos.org/p/1217

描述

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

比赛规则和实际比赛规则相同, 在11分制下比分为10:11时还要继续比赛,直到分数差距达到2分;同理21分制下比分为20:21的时候也还要继续比赛。

比如现在有这么一份记录,(其中W表示华华获得一分,L表示华华对手获得一分):
WWWWWWWWWWWWWWWWWWWWWWLW
在11分制下,此时比赛的结果是华华第一局11比0获胜,第二局11比0获胜,正在进行第三局,当前比分1比1。而在21分制下,此时比赛结果是华华第一局21比0获胜,正在进行第二局,比分2比1。如果一局比赛刚开始,则此时比分为0比0。

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

格式

输入格式

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

输出格式

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

样例1

样例输入1[复制]

WWWWWWWWWWWWWWWWWWWW
WWLWE

样例输出1[复制]

11:0
11:0
1:1

21:0
2:1

限制

各个测试点1s

这个题目真的是好坑。。。得注意每次只有一组数据,有回车,醉了。。。刚开始还以为是样例格式问题。。。

还有就是说的好的按输入信息输出分数呢,结果自己按W,L的比分输出就可以了。。。

代码:

#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
#include<algorithm>
using namespace std;
int main()
{
int t=0;
char s[1000000];
while(cin>>s[t]&&s[t]!='E') t++;
int t1=0,t2=0,i;
int flag=0;
for(i=0;i<t;i++){
if(s[i]=='W'){
if(!t1&&!t2) flag=1;
t1++;
}else if(s[i]=='L'){
if(!t1&&!t2) flag=0;
t2++;
}else continue;
if((t1>=11||t2>=11)&&(abs(t1-t2)>1)){
cout<<t1<<':'<<t2<<endl;
t1=0;t2=0;
}
}
cout<<t1<<':'<<t2<<endl<<endl;
t1=0,t2=0,flag=0;
for(i=0;i<t;i++){
if(s[i]=='W'){
if(!t1&&!t2) flag=1;
t1++;
}else if(s[i]=='L'){
if(!t1&&!t2) flag=0;
t2++;
}else continue;
if((t1>=21||t2>=21)&&(abs(t1-t2)>1)){
cout<<t1<<':'<<t2<<endl;
t1=0;t2=0;
}
}
cout<<t1<<':'<<t2<<endl;
return 0;
}