博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
简单错误记录
阅读量:6226 次
发布时间:2019-06-21

本文共 2545 字,大约阅读时间需要 8 分钟。

简单错误记录

题目描述

开发一个简单错误记录功能小模块,能够记录出错的代码所在的文件名称和行号。 
处理:
1.记录最多8条错误记录,对相同的错误记录(即文件名称和行号完全匹配)只记录一条,错误计数增加;(文件所在的目录不同,文件名和行号相同也要合并)
2.超过16个字符的文件名称,只记录文件的最后有效16个字符;(如果文件名不同,而只是文件名的后16个字符和行号相同,也不要合并)
3.输入的文件可能带路径,记录文件名称不能带路径

输入描述:

一行或多行字符串。每行包括带路径文件名称,行号,以空格隔开。     文件路径为windows格式     如:E:\V1R2\product\fpgadrive.c 1325

输出描述:

将所有的记录统计并将结果输出,格式:文件名代码行数数目,一个空格隔开,如: fpgadrive.c 1325 1     结果根据数目从多到少排序,数目相同的情况下,按照输入第一次出现顺序排序。     如果超过8条记录,则只输出前8条记录.     如果文件名的长度超过16个字符,则只输出后16个字符
示例1

输入

E:\V1R2\product\fpgadrive.c 1325

输出

fpgadrive.c 1325 1

 

牛客网题解:

1 //先将所有的字符串存入哈希表,key为字符串,value为
<出现顺序,出现次数>
,顺序取相同的字符串的最小值,次数一直累加 2 //排序的话,利用set重写比较器,按次数降序,次数相同则按出现顺序排列 3 //插入过程利用hash时间复杂度可以认为是O(n) 4 //排序过程set的是红黑树,可以认为是O(nlgn) ,总的复杂度就是这个了 5 #include
6 #include
7 #include
8 #include
9 using namespace std;10 struct info{
//记录出现的顺序,和次数11     int rank;12     int count;13     info(int rank,int count){14         this->rank=rank;15         this->count=count;16     }17 };18 struct fullinfo{
//一条完整的结果,字符串和次数19     string file;20     int rank;21     int count;22     fullinfo(string file,int rank,int count){23         this->file=file;24         this->rank=rank;25         this->count=count;26     }27 };28 struct classcomp {
//set的比较器29   bool operator()(const struct fullinfo& f1,const struct fullinfo& f2){30         if(f1.count==f2.count)31             return f1.rank
f2.count;33     }34 };35 typedef struct info INFO;36 typedef struct fullinfo FULLINFO;37 int main(){38     unordered_map
record;39     unordered_map
::iterator it;40     unordered_map
::const_iterator itfind;41     set
ret;42     set
::iterator sit;43     string linestr;//一行输入44     string file;//文件名+行号45     int pos;//空格的位置46     int i=1;47     while(getline(cin,linestr)){48         if(linestr.length()==0)49             break;50         pos=linestr.rfind("\\");51         file=linestr.substr(pos+1);//拆分得到最后的filename和count52         itfind=record.find(file);//在map中查看是否已经有了该字符串,没有则插入,有则次数加153         if(itfind==record.end()){54             INFO tmpi(i,1);55             record.insert(pair
(file,tmpi));56         }57         else{58             INFO tmpi(itfind->second.rank,itfind->second.count+1);59             record.erase(file);60             record.insert(pair
(file,tmpi));61         }62         i++;63     }64     for(it=record.begin();it!=record.end();it++){65         FULLINFO tmpfull(it->first,it->second.rank,it->second.count);//构建排序的set集合66         ret.insert(tmpfull);67     }68     for(i=0,sit=ret.begin();sit!=ret.end()&&i<8;++sit,++i){ //最多输出8条记录,file少于16位69         if(file.find(" ")<=16){70             cout<<(*sit).file<<" "<<(*sit).count<

 

转载于:https://www.cnblogs.com/Renyi-Fan/p/7780309.html

你可能感兴趣的文章
下MFC中对象、句柄、ID之间的区别.
查看>>
Flymeos插桩适配教程
查看>>
大端模式与小端模式、网络字节顺序与主机字节顺序
查看>>
微信支付申请90%的商户都卡在这儿了,申请微信支付,商户功能设置详细说明...
查看>>
高仿Instagram 页面效果android特效
查看>>
2016 年总结
查看>>
将String转化成Stream,将Stream转换成String
查看>>
【工具使用系列】关于 MATLAB 遗传算法与直接搜索工具箱,你需要知道的事
查看>>
Kali-linux Arpspoof工具
查看>>
PDF文档页面如何重新排版?
查看>>
基于http协议使用protobuf进行前后端交互
查看>>
bash腳本編程之三 条件判断及算数运算
查看>>
php cookie
查看>>
linux下redis安装
查看>>
弃 Java 而使用 Kotlin 的你后悔了吗?| kotlin将会是最好的开发语言
查看>>
JavaScript 数据类型
查看>>
量子通信和大数据最有市场突破前景
查看>>
对‘初学者应该选择哪种编程语言’的回答——计算机达人成长之路(38)
查看>>
如何申请开通微信多客服功能
查看>>
Sr_C++_Engineer_(LBS_Engine@Global Map Dept.)
查看>>