链接:https://www.nowcoder.com/questionTerminal/2baa6aba39214d6ea91a2e03dff3fbeb
来源:牛客网
开发一个简单错误记录功能小模块,能够记录出错的代码所在的文件名称和行号。
处理:
1、 记录最多8条错误记录,循环记录,对相同的错误记录(净文件名称和行号完全匹配)只记录一条,错误计数增加;
2、 超过16个字符的文件名称,只记录文件的最后有效16个字符;
3、 输入的文件可能带路径,记录文件名称不能带路径。
输入描述:
一行或多行字符串。每行包括带路径文件名称,行号,以空格隔开。
输出描述:
将所有的记录统计并将结果输出,格式:文件名 代码行数 数目,一个空格隔开,
如:示例1
输入 E:\V1R2\product\fpgadrive.c 1325
输出 fpgadrive.c 1325 1
【题目解析】:
注意:题目中的净文件名指:如果一个文件路径为 c:\test\test.c
,那么净文件名就是 test.c
。
【解题思路】:
实现过程比较简单,按照题目需求操作即可。
记录个数,故想到使用 Map,不需要排序故使用 HashMap,根据题意是要循环输出,而且提交一次会有测试用例提示,需要按照输入顺序输出,故使用LinkedHashMap。在输出的时候,在输出的时候,题目的意思是循环 8 个,但问题是必须记录全部错误个数,否则刚记录完后弹出了,错误数就对不上了,那么只要取后 8 条错误记录就可以了。
【代码展示】:
import java.util.*;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
Map<String, Integer> map = new LinkedHashMap<>();
while(sc.hasNext()) {
String str = sc.next();
int lineNum = sc.nextInt();
String[] arr = str.split("\\\\");//把\进行转义
String s = arr[arr.length - 1];
if(s.length() > 16) {//如果文件名大于16位就截取后16位
s = s.substring(s.length()-16);
}
String key = s + " " + lineNum;
if(!map.containsKey(key)) {
map.put(key, 1);
}else {
map.put(key, map.get(key) + 1);
}
}
int count = 0;
for(String string : map.keySet()) {
count++;
//输出最后8个记录
if(count > (map.keySet().size() - 8)) {
System.out.println(string + " " + map.get(string));
}
}
}
}