一、描述
首先将比赛每个球的胜负列成一张表,然后分别计算在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分制下的结果,两部分之间由一个空行分隔。
三、思路
重点在于对每一局比赛结果的判断: 比分是否超过了10:11或者20:21。
未超过时,需要满足条件:分值差的绝对值小于等于2;其中一方得分值等于11或21
超过时,需要满足条件:分值差的绝对值等于2;其中一方得分值大于11或21
四、代码
import java.io.File;
import java.io.FileReader;
import java.io.IOException;
public class Main {
static char[] ch = new char[100000]; //存放文件中的字符
public static void main(String[] args) {
// TODO auto-generated method stub
File file = new File("D://a.txt");
int i = 0; //标记数组ch[]的长度
int tmp = 0;
try {
FileReader fileReader = new FileReader(file); // 注意 fileReader.read() 和 tmp = fileReader.read() 的区别
while (((tmp = fileReader.read()) != 'E')) {
if (tmp != 10 && tmp != 13 && tmp != 32) {
ch[i] = (char) tmp;
i++;
}
}
/*
while (((fileReader.read()) != 'E')) { //此处已经read()一次了
if (tmp != 10 && tmp != 13 && tmp != 32) {
ch[i] = (char) fileReader.read(); //此处又 read()一次,会造成没有把文件中的内容全部存储到数组中的情况
i++;
}
}
*/
} catch (IOException e) {
// TODO auto-generated catch block
e.printStackTrace();
}
grades(i, 11);
System.out.println();
grades(i, 21);
}
public static void grades(int len,int type) {
int w =0;
int l =0;
for (int i = 0; i < len; i++) {
if (ch[i] == 'W') {
w++;
}
if(ch[i]=='L'){
l++;
}
if (((w == type || l == type) && (Math.abs(w - l) >= 2))
|| ((w > type || l > type) && (Math.abs(w - l) == 2))) {
System.out.println(w + ":" + l);
w = 0;
l = 0;
}
}
System.out.println(w + ":" + l); //输出新的一局已经开始但并没有比赛结束的情况
}
}