【华为OJ19】简单错误记录
来源:互联网 发布:win7开机优化加速 编辑:程序博客网 时间:2024/06/15 09:45
首先理解错了题目意思,做法也很复杂:
import java.util.Scanner;import java.util.Set;import java.util.TreeSet;/** * 开发一个简单错误记录功能小模块,能够记录出错的代码所在的文件名称和行号。1、 记录最多8条错误记录,循环记录,对相同的错误记录(净文件名称和行号完全匹配)只记录一条,错误计数增加;2、 超过16个字符的文件名称,只记录文件的最后有效16个字符;3、 输入的文件可能带路径,记录文件名称不能带路径。输入描述:一行或多行字符串。每行包括带路径文件名称,行号,以空格隔开。输出描述:将所有的记录统计并将结果输出,格式:文件名 代码行数 数目,一个空格隔开,如:输入例子:E:\V1R2\product\fpgadrive.c 1325输出例子:fpgadrive.c 1325 1 * @author WGS */public class Main {private static int errorItems=0;private static void RecordingErrorLogs(Set<String> set,String[] input) {//input[0]文件路径:E:\V1R2\product\fpgadrive.c input[1]行号:1325String fileName="";String rowNumStr="";//1 获取文件名,超过长度16的截取int index1=input[0].lastIndexOf("\\");//最后一个斜杠位置int lenthOfFile=input[0].length()-index1-1;if(lenthOfFile>16){index1=input[0].length()-16;}//2 获取行号rowNumStr=input[1];String validStr= fileName +","+ rowNumStr;//3 验证:对相同的错误记录(净文件名称和行号完全匹配)只记录一条,错误计数增加;if(!set.add(validStr)){ set.add(validStr);errorItems++;//有重复}}private static String setToString(Set<String> set){StringBuilder sb=new StringBuilder(256);for(String s:set){String[] tempStr=s.split(",");sb.append(tempStr[0]).append(" ").append(tempStr[1]).append(" ").append(errorItems).append("\n");}return sb.toString();}public static void main(String[] args) {Scanner sc=new Scanner(System.in);Set<String> set=new TreeSet<>();while(sc.hasNext()){for(int i=0;i<8;i++){String[] input=sc.nextLine().split("\\s+");RecordingErrorLogs(set,input);}System.out.println(setToString(set));}sc.close();}}
package com.oj.test;import java.util.LinkedHashMap;import java.util.Map;import java.util.Scanner; public class Main{ public static void main(String[] args) { Scanner sc=new Scanner(System.in); Map<String, Integer> map=new LinkedHashMap<String, Integer>(); 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) //截取 s=s.substring(s.length()-16); String key=s+" "+linenum; int value=1; if(map.containsKey(key)) map.put(key, map.get(key)+1); else { map.put(key, value); } } int count=0; for(String string:map.keySet()){ count++; if(count>(map.keySet().size()-8)) //输出最后八个记录 System.out.println("***"+string+" "+map.get(string)); } }}
自己重新做了一遍,整理了一下思路:
package com.oj.exe2;import java.util.LinkedHashMap;import java.util.Map;import java.util.Map.Entry;import java.util.Scanner;import java.util.Set;import java.util.TreeSet;/** * 开发一个简单错误记录功能小模块,能够记录出错的代码所在的文件名称和行号。1、 记录最多8条错误记录,循环记录,对相同的错误记录(净文件名称和行号完全匹配)只记录一条,错误计数增加;2、 超过16个字符的文件名称,只记录文件的最后有效16个字符;3、 输入的文件可能带路径,记录文件名称不能带路径。输入描述:一行或多行字符串。每行包括带路径文件名称,行号,以空格隔开。输出描述:将所有的记录统计并将结果输出,格式:文件名 代码行数 数目,一个空格隔开,如:输入例子:E:\V1R2\product\fpgadrive.c 1325输出例子:fpgadrive.c 1325 1 * @author WGS */public class Exe19_2 {private static void RecordingErrorLogs(Map<String, Integer> map,String fileLocation,int lineNum) {//1 获取文件名,超过长度16的截取int index1=fileLocation.lastIndexOf("\\");//最后一个斜杠位置int lenthOfFile=fileLocation.length()-index1-1;if(lenthOfFile>16){index1=fileLocation.length()-16;}String fileName=fileLocation.substring(index1+1);//2 将文件路径和行号连接为字符串,作为map的key键值String inputStr= fileName +" "+ lineNum;//3 验证:对相同的错误记录(净文件名称和行号完全匹配)只记录一条,错误计数增加;if(map.containsKey(inputStr)){map.put(inputStr,map.get(inputStr)+1);}else{//没有重复的,次数就设置为1map.put(inputStr,1);}}public static void main(String[] args) {Scanner sc=new Scanner(System.in);//不需要排序,所以使用LinkedHashMapMap<String, Integer> map=new LinkedHashMap<String, Integer>();while(sc.hasNext()){String fileLocation=sc.next();int lineNum=sc.nextInt();//输一条信息,记录一条RecordingErrorLogs(map,fileLocation,lineNum);}//遍历map的key键值(含有文件+行号信息),输出最后的八条记录;int count=0;for(String s:map.keySet()){count++;if(count>(map.keySet().size()-8))//从倒数第八条开始遍历System.out.println(s+" "+map.get(s));//文件路径行号+个数}sc.close();}}
结果在eclipse中能够完全通过(使用他给的测试用例),牛客上只通过30%,考虑到////代表两个//的意思,可能是输入路径中的“\”被转义成"//"了,所以应该这样:
import java.util.LinkedHashMap;import java.util.Map;import java.util.Map.Entry;import java.util.Scanner;/** * 开发一个简单错误记录功能小模块,能够记录出错的代码所在的文件名称和行号。1、 记录最多8条错误记录,循环记录,对相同的错误记录(净文件名称和行号完全匹配)只记录一条,错误计数增加;2、 超过16个字符的文件名称,只记录文件的最后有效16个字符;3、 输入的文件可能带路径,记录文件名称不能带路径。输入描述:一行或多行字符串。每行包括带路径文件名称,行号,以空格隔开。输出描述:将所有的记录统计并将结果输出,格式:文件名 代码行数 数目,一个空格隔开,如:输入例子:E:\V1R2\product\fpgadrive.c 1325输出例子:fpgadrive.c 1325 1 * @author WGS */public class Main {private static void RecordingErrorLogs(Map<String, Integer> map,String fileLocation,int lineNum) {//input[0]文件路径:E:\V1R2\product\fpgadrive.c input[1]行号:1325//1 获取文件名,超过长度16的截取String[] arr=fileLocation.split("\\\\");//分解:>>E: \\ V1R2 \\ product \\ fpgadrive.cString fileName=arr[arr.length-1];if(fileName.length()>16){fileName=fileName.substring(fileName.length()-16);}//2 将文件路径和行号连接为字符串,作为map的key键值String inputStr= fileName +" "+ lineNum;//3 验证:对相同的错误记录(净文件名称和行号完全匹配)只记录一条,错误计数增加;if(map.containsKey(inputStr)){map.put(inputStr,map.get(inputStr)+1);}else{//没有重复的,次数就设置为1map.put(inputStr,1);}}public static void main(String[] args) {Scanner sc=new Scanner(System.in);//不需要排序,所以使用LinkedHashMapMap<String, Integer> map=new LinkedHashMap<String, Integer>();while(sc.hasNext()){String fileLocation=sc.next();int lineNum=sc.nextInt();//输一条信息,记录一条RecordingErrorLogs(map,fileLocation,lineNum);}//遍历map的key键值(含有文件+行号信息),输出最后的八条记录;int count=0;for(String s:map.keySet()){count++;if(count>map.size()-8)//从倒数第八条开始遍历System.out.println(s+" "+map.get(s));//文件路径行号+个数}sc.close();}}
0 0
- 【华为OJ19】简单错误记录
- 【华为】简单错误记录
- 华为oj 简单错误记录
- 【华为OJ】简单错误记录
- 华为OJ-------简单错误记录
- 华为-简单错误记录-Java
- [华为机试题]简单错误记录
- 华为OJ(简单错误记录)
- 华为机试-简单错误记录
- 【华为OJ】【069-简单错误记录】
- [华为机试]简单错误记录
- 华为OJ——简单错误记录
- 华为机试---简单错误记录
- 华为2016校园招聘:简单错误记录
- 【华为OJ】简单错误记录【未完成】
- 华为机试-简单错误记录
- 华为oj中级 简单错误记录
- 华为OJ-简单错误记录模块
- C语言实现控制行数打印星号金字塔
- java中返回值return的使用
- from now on...
- 深刻的理解Fragment生命周期 都在做什么
- C++本质:类的赋值运算符=的重载,以及深拷贝和浅拷贝
- 【华为OJ19】简单错误记录
- BZOJ 1935
- mysql 自定义hash索引
- MapReduce 例子
- Java中HashMap中对value对象进行排序
- iOS推送
- LXH必备技能
- Postfix expressions(Data Structure)
- 用c语言验证哥德巴赫猜想