Vijos P1217 乒乓球【模拟+输入输出】
描述
华华通过以下方式进行分析,首先将比赛每个球的胜负列成一张表,然后分别计算在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
提示
十分简单,小心输入输出格式!^_^
问题链接:Vijos P1217 乒乓球
问题分析:
这个问题是一个单纯的计算问题,逻辑并不复杂。
程序说明:能不用存储就应该不用存储。按字符流来处理的话,输入存储就省去了。
使用字符流变量暂存输出结果是一种比较好的做法,可以使得程序逻辑变得简洁。
本程序没有将公用的逻辑封装到函数中,这样做可以使得程序逻辑更加易读易懂。
题记:
玩程序玩的就是时间和空间,不影响大原则的前提下,要能省则省。
参考链接:(略)
AC的C++程序如下:
#include <iostream> #include <sstream> using namespace std; const int P11 = 11; const int P21 = 21; int main() { char c; int p11a, p11b, p21a, p21b; ostringstream ans11, ans21; p11a = p11b = p21a = p21b = 0; while(cin >> c) { if(c == 'E') break; else if(c == 'W') { // 11分制计算 if(++p11a >= P11 && p11a - p11b >= 2) { ans11 << p11a << ":" << p11b << endl; p11a = p11b = 0; } // 21分制计算 if(++p21a >= P21 && p21a - p21b >= 2) { ans21 << p21a << ":" << p21b << endl; p21a = p21b = 0; } } else if(c == 'L') { // 11分制计算 if(++p11b >= P11 && p11b - p11a >= 2) { ans11 << p11a << ":" << p11b << endl; p11a = p11b = 0; } // 21分制计算 if(++p21b >= P21 && p21b - p21a >= 2) { ans21 << p21a << ":" << p21b << endl; p21a = p21b = 0; } } } ans11 << p11a << ":" << p11b << endl << endl; ans21 << p21a << ":" << p21b << endl; cout << ans11.str() << ans21.str(); return 0; }