乒乓球早期曾采用21分制,经过改革后现在的赛制主流采用11分制,现在需要对多年比赛的统计数据进行一些分析。
具体通过以下方式进行分析,首先将比赛每个球的胜负列成一张表,然后分别计算在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
解题思路:
(1)处理输入:获得E符号前的符号,保存在字符串中;
(2)处理字符串中的得分;
(2.1)设置11分赛制成绩单,设置21分赛制成绩单,(用队列或列表或数组都可以)
(2.2)对每个得分符号,记录选手得分,判断本局是否结束,如果结束,就将成绩计入对应赛制的成绩单,并开新局;(注意一局结束的条件!)
(2.3)处理完所有得分,将当前的一局的得分记入两个成绩单;
(2.4)按规定格式,输出两个成绩单;
其中:需要记录每一局的得分,定义类Game,表示一局比赛,需要用到的成员变量有:双方的得分、赛制;成员方法有:根据赛制开局(构造方法),记录得分,判断是否本局结束,本局得分。
定义Game类如下:
class Game { //一局,
int W;
int L;
int format; //赛制,11分或21分
Game(int format) {
W = 0;
L = 0;
this.format = format;
}
boolean isOver() { //是否一局结束
if (W >= format && (W - L) >= 2 || L >= format && (L - W) >= 2)
return true;
else
return false;
}
void point(char ch) { //得分
if (ch == 'W')
W++;
else
L++;
}
String getScore() { //比分
return this.W + ":" + this.L;
}
}
自动判分的处理过程如下:
public class Main {
public static void stats(String allPoint) //自动判分的处理
{
Queue<String> scoreTable_11 = new LinkedList<String>(); //记录11分制下的得分表
Queue<String> scoreTable_21 = new LinkedList<String>(); //记录21分制下的得分表
Game game_11 = new Game(11); //开新局
Game game_21 = new Game(21); //开新局
for(int i=0;i<allPoint.length();i++) {
char s = allPoint.charAt(i);
//按11分制处理一个得分,先计分,再判断是否本局结束,如果结束就将成绩计入得分表
game_11.point(s);
if(game_11.isOver()) {
scoreTable_11.offer(game_11.getScore());
game_11 = new Game(11);
}
//按21分制处理一个得分,先计分,再判断是否本局结束,如果结束就将成绩计入得分表
game_21.point(s);
if(game_21.isOver()) {
scoreTable_21.offer(game_21.getScore());
game_21 = new Game(21);
}
}
scoreTable_11.offer(game_11.getScore());//将当前得分记入得分表
scoreTable_21.offer(game_21.getScore());//将当前得分记入得分表
//输出各成绩单的结果
for(String str:scoreTable_11) {
System.out.println(str);
}
System.out.println();
for(String str:scoreTable_21) {
System.out.println(str);
}
}
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
//处理输入数据,将E之前的计分保存在allPoint中
String allPoint = "";
while (true) {
String str=sc.nextLine();
allPoint += str;
if(str.contains("E")) {
allPoint = allPoint.substring(0, allPoint.indexOf("E"));
break;
}
}
//对allPoint中的记分进行自动判分的处理
stats(allPoint);
sc.close();
}
}