首页 > 试题广场 >

简单错误记录

[编程题]简单错误记录
  • 热度指数:362144 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 32M,其他语言64M
  • 算法知识视频讲解
\hspace{15pt}在本题中,我们需要处理文件报错信息,其由出错文件的文件路径和错误行号组成。

\hspace{15pt}文件路径的前三个字母为大写字母 \texttt{A-Z} 、冒号 \texttt{ 和反斜杠 \texttt{ ,代表盘符;随后是若干由小写字母构成的字符串,代表文件夹名,彼此使用单个反斜杠间隔。路径的最后一个反斜杠后是文件名。
\hspace{15pt}我们只在乎文件名(即去掉除了文件名以外的全部信息),且至多保留文件名的最后 16 个字符。

\hspace{15pt}随后,我们需要统计相同的报错信息:
\hspace{23pt}\bullet\,如果两条报错信息保留后 16 个字符后的文件名相同,且行号相同,则视为同一个报错;

\hspace{15pt}相同的报错信息以第一次出现的时间为准,至多输出最后 8 条记录。

输入描述:
\hspace{15pt}本题将会给出 1 \leqq T \leqq 100 条报错信息,确切数字未知,您需要一直读入直到文件结尾;您也可以参考 牛客网在线判题系统使用帮助 获得更多的使用帮助。每条报错信息描述如下:

\hspace{15pt}在一行上先输入一个长度为 1 \leqq {\rm length}(x) \leqq 100 的字符串 x 代表文件路径;随后,在同一行输入一个整数 y \left( 1 \leqq y \leqq 1000 \right) 代表行号。
\hspace{15pt}文件路径的格式如题干所述,保证文件名不为空。


输出描述:
\hspace{15pt}至多八行,每行先输出一个长度为 1 \leqq {\rm length}(s) \leqq 16 的字符串 s ,代表文件名;随后,在同一行输出错误行号、报错次数。
示例1

输入

D:\oblemsinnowcoder 12
D:\nowcoderproblemsinnowcoder 12
D:\nowcoder\problemsinnowcoder 13
D:\oj\problemsinnowcoder 13

输出

oblemsinnowcoder 12 2
oblemsinnowcoder 13 2

说明

\hspace{15pt}在这个样例中,这四条报错信息去除文件路径后,由于文件名长度均超过 16 个字符,故我们只保留最后 16 个字符,得到的文件名均为 \texttt{ 。所以,我们将它们看作同一个文件,按照报错行号划分即可。
示例2

输入

A:\aa 1
B:\b 1
C:\c 1
D:\d 1
E:\e 1
F:\f 1
G:\g 1
H:\h 1
I:\i 1
A:\aa 1

输出

b 1 1
c 1 1
d 1 1
e 1 1
f 1 1
g 1 1
h 1 1
i 1 1

说明

\hspace{15pt}在这个样例中,第一、十条报错信息完全相同,但是我们以其第一次出现的顺序为准,在输出最后 8 条记录时,不包含这一报错。
示例3

输入

D:\zwtymj\xccb\ljj\cqzlyaszjvlsjmkwoqijggmybr 645
E:\je\rzuwnjvnuz 633
C:\km\tgjwpb\gy\atl 637
F:\weioj\hadd\connsh\rwyfvzsopsuiqjnr 647
E:\ns\mfwj\wqkoki\eez 648
D:\cfmwafhhgeyawnool 649
E:\czt\opwip\osnll\c 637
G:\nt\f 633
F:\fop\ywzqaop 631
F:\yay\jc\ywzqaop 631
D:\zwtymj\xccb\ljj\cqzlyaszjvlsjmkwoqijggmybr 645

输出

rzuwnjvnuz 633 1
atl 637 1
rwyfvzsopsuiqjnr 647 1
eez 648 1
fmwafhhgeyawnool 649 1
c 637 1
f 633 1
ywzqaop 631 2
头像 Tasen
发表于 2021-09-29 00:09:20
l = [] ll = [] while 1: try: s = input().split('\\')[-1] data = s.split(' ')[0][-16:] + ' ' + s.split(' ')[1] if data not 展开全文
头像 时间会变白
发表于 2021-08-14 22:43:50
#include <iostream> #include <string> #include <deque> #include <map> using std::cin; using std::cout; using std::endl; using 展开全文
头像 姜昊_
发表于 2022-04-05 22:58:41
小白解题思路,可能对初学者友好一点。 ls = [] # 储存键 dic = {} # 储存键-值对 while True: try: msg = input().split() msg[0] = msg[0].split('\\')[-1] 展开全文
头像 binchg
发表于 2020-03-03 21:45:09
java 26行较短写法不容易出错,坑点:循环输出的顺序指的是第一次插入的循序而不是最后一次使用,使用linkedhashmap有序插入特征,使用bufferedreader比scanner较快输入运行时间:16ms占用内存:9596k import java.io.*; import java.u 展开全文
头像 Joy917
发表于 2021-09-07 23:59:13
import java.io.*; import java.util.*; public class Main{ public static void main(String[] args) throws IOException{ BufferedReader bf = ne 展开全文
头像 Joe--
发表于 2021-11-09 17:55:55
/** 1.过滤截取路径 2.增加数量 */ let obj = {} let str; while(str = readline()) { const [c, n] = str.split(" "); const s = c.substr(c.lastIndexOf('\\') + 展开全文
头像 摸鱼学大师
发表于 2021-10-10 19:14:05
题目的主要信息: 开发一个简单错误记录功能小模块,能够记录出错的代码所在的文件名称和行号,及相同错误出现的次数 记录最多8条错误记录,循环记录,最后只用输出最后出现的八条错误记录 对相同的错误记录只记录一条,但是错误计数增加,最后一个斜杠后面的带后缀名的部分(保留最后16位)和行号完全匹配的记录才 展开全文
头像 牛客661737198号
发表于 2020-07-26 14:41:03
40行c++解决,代码清晰易懂 #include<iostream> #include<vector> #include<map> using namespace std; string decomp(string filepath){ int end 展开全文
头像 古月悟天
发表于 2021-11-30 13:09:54
#include<stdio.h> #include<string.h> typedef struct ErrRecord { char name[20]; int line; int count; }ErrRecord; int main() { 展开全文
头像 代码界的小白
发表于 2021-12-03 15:36:06
题目主要信息 1、开发一个记录功能小模块,可以记录出错的代码所在的文件名称和行号。 2、最多可记录8条错误记录,只用输出最后出现八条错误记录。针对相同过的错误记录只记录一条,但数量增加。(最后一个斜杠后面的带后缀名的部分,保留最后16位,和行号完全匹配的记录算相同的记录) 3、超过16个字符的文件名 展开全文