[牛客网] 简单错误记录

链接: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));
            }
        }
    }
}

你可能感兴趣的:(笔试题)