乒乓球
2015-10-29 07:27
281 查看
题目描述
国际乒联现在主席沙拉拉自从上任以来就立志于推行一系列改革,以推动乒乓球运动在全球的普及。其中11分制改革引起了很大的争议,有一部分球员因为无法适应新规则只能选择退役。华华就是其中一位,他退役之后走上了乒乓球研究工作,意图弄明白11分制和21分制对选手的不同影响。在开展他的研究之前,他首先需要对他多年比赛的统计数据进行一些分析,所以需要你的帮忙。
华华通过以下方式进行分析,首先将比赛每个球的胜负列成一张表,然后分别计算在11分制和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之后的所有内容。
输出
输出由两部分组成,每部分有若干行,每一行对应一局比赛的比分(按比赛信息输入顺序)。其中第一部分是11分制下的结果,第二部分是21分制下的结果,两部分之间由一个空行分隔。
样例输入
样例输出
在做此道题之前必须了解乒乓球的比分规则,当11分制时,如果双方都是10:10,则多得到两份的人胜,所以只需要判断他们差的绝对值是否大于等于2.
国际乒联现在主席沙拉拉自从上任以来就立志于推行一系列改革,以推动乒乓球运动在全球的普及。其中11分制改革引起了很大的争议,有一部分球员因为无法适应新规则只能选择退役。华华就是其中一位,他退役之后走上了乒乓球研究工作,意图弄明白11分制和21分制对选手的不同影响。在开展他的研究之前,他首先需要对他多年比赛的统计数据进行一些分析,所以需要你的帮忙。
华华通过以下方式进行分析,首先将比赛每个球的胜负列成一张表,然后分别计算在11分制和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之后的所有内容。
输出
输出由两部分组成,每部分有若干行,每一行对应一局比赛的比分(按比赛信息输入顺序)。其中第一部分是11分制下的结果,第二部分是21分制下的结果,两部分之间由一个空行分隔。
样例输入
WWWWWWWWWWWWWWWWWWWW WWLWE
样例输出
11:0 11:0 1:1 21:0 2:1
在做此道题之前必须了解乒乓球的比分规则,当11分制时,如果双方都是10:10,则多得到两份的人胜,所以只需要判断他们差的绝对值是否大于等于2.
#include <stdio.h> #include <string.h> #include <stdlib.h> const int maxn = 205; char str[maxn]; int a[2][maxn*100], b[2][maxn*100]; //数组放大点 //这道题还需要乒乓球的规则 //在一局比赛中,先得11分的一方为胜方;比分出现10平后,先多得2分的—方为胜方 int main ( ) { //freopen ( "in0.out", "w", stdout ); int len, cnt, ew, sl, c1, c2, sw, el, flag; flag = cnt = c1 = c2 = ew = el = sw = sl = 0; while ( ~ scanf ( "%s", str ) ) { int len = strlen ( str ); for ( int i = 0; i < len; i ++, cnt ++ ) { if ( ( ew >= 11 || el >= 11 ) && abs ( ew-el ) >= 2 ) //当有一个超过11时就需要判断分数是否大于等于2 { a[0][c1] = ew; a[1][c1 ++] = el; ew = el = 0; } if ( ( sw >= 21 || sl >= 21 ) && abs ( sw-sl ) >= 2 ) { b[0][c2] = sw; b[1][c2 ++] = sl; sw = sl = 0; } if ( str[i] == 'W' ) { ew ++; sw ++; } if ( str[i] == 'L' ) { el ++; sl ++; } if ( str[i] == 'E' ) //当E时直接退出 { flag = 1; break ; } } if ( flag ) break ; } for ( int i = 0; i < c1; i ++ ) printf ( "%d:%d\n", a[0][i], a[1][i] ); printf ( "%d:%d\n", ew, el ); //输出最后一组 printf ( "\n" ); for ( int i = 0; i < c2; i ++ ) printf ( "%d:%d\n", b[0][i], b[1][i] ); printf ( "%d:%d\n", sw, sl ); return 0; }
相关文章推荐
- 挑战这十七项编程 锻炼大脑并且提升能力
- OSChina 周四乱弹 —— 人生处处是深坑
- NOIP2015游玩记
- 利用Service后台播放音乐实例
- Android Api Demos登顶之路(111)Views-->Seacure View
- 防sql攻击演示SQL攻击
- SpriteBuilder中节点位置类型为百分比时不能定位的解决
- SpriteBuilder中节点位置类型为百分比时不能定位的解决
- SpriteBuilder中节点位置类型为百分比时不能定位的解决
- 美国军方网站还在用老旧的 SHA-1 证书
- BigDecimal的用法简介
- 数据库部门数据生成xml树
- 140. Word Break II (String; DP)
- 恶意软件感染MySQL服务器 成为全球DDoS僵尸网络一部分
- sgit增加搜索功能
- 5.2 Binary to String
- Find Minimum in Rotated Sorted Array
- 面试总结2015-10-29
- Convert Sorted Array to Binary Search Tree - LeetCode
- 5.6 Conversion