描述
开发一个简单错误记录功能小模块,能够记录出错的代码所在的文件名称和行号。
处理:
1、 记录最多8条错误记录,循环记录,最后只用输出最后出现的八条错误记录。对相同的错误记录只记录一条,但是错误计数增加。最后一个斜杠后面的带后缀名的部分(保留最后16位)和行号完全匹配的记录才做算是“相同”的错误记录。
2、 超过16个字符的文件名称,只记录文件的最后有效16个字符;
3、 输入的文件可能带路径,记录文件名称不能带路径。也就是说,哪怕不同路径下的文件,如果它们的名字的后16个字符相同,也被视为相同的错误记录
4、循环记录时,只以第一次出现的顺序为准,后面重复的不会更新它的出现时间,仍以第一次为准
数据范围:错误记录数量满足 1 \le n \le 100 \1≤n≤100 ,每条记录长度满足 1 \le len \le 100 \1≤len≤100
输入描述:
每组只包含一个测试用例。一个测试用例包含一行或多行字符串。每行包括带路径文件名称,行号,以空格隔开。
输出描述:
将所有的记录统计并将结果输出,格式:文件名 代码行数 数目,一个空格隔开,如:
import java.util.*;
// 注意类名必须为 Main, 不要有任何 package xxx 信息
public class Main {
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
HashMap<String, Integer> map = new HashMap<>();
// 根据queue的特性 队列先进先出,其只能删最先进入的第一个元素,只能在队列后面添加元素
Queue<String> q = new LinkedList<>();
while(in.hasNextLine()){
String temp = in.nextLine();
String[] arr = temp.split(" ");
String adr = arr[0];
String[] adrArr = adr.split("\\\\");
String av = adrArr[adrArr.length - 1];
int l = av.length();
String k = av.substring(av.length() < 16 ? 0 : (av.length() - 16)) + " " + arr[1];
Integer a ;
if((a = map.get(k)) == null){
map.put(k, 1);
q.offer(k);
if(q.size() > 8){
q.poll();
}
}else{
map.put(k, ++a);
}
}
for(String param : q){
Integer r = map.get(param);
System.out.println(param + " " + r);
}
}
}