题解 | #简单错误记录#
简单错误记录
https://www.nowcoder.com/practice/2baa6aba39214d6ea91a2e03dff3fbeb
使用三个vector 数组做hash映射:
name:文件名
col : 错误行数
count: 计数
每获得一条err信息,先查询之前有无这条信息。查询到则,对count++,否则直接添加这条数据到三个hash表中。
注意:查询到意味着 name 和col都是符合的。
输出时,只需要输出最后8条数据即可,不满足8条则全部输出。
#include<iostream>
#include<sstream>
#include<string>
#include<map>
#include<vector>
using namespace std;
int main(){
string s;
int n;
vector<string> name ;
vector<int> col ;
vector<int> count ;
while(cin>>s>>n){
istringstream iss(s);
string ss;
while(getline(iss,ss,'\\')){}
string fn =ss.length()>=16? ss.substr(ss.length()-16):ss;
// cout<<fn<<endl;
int find = 0;
for(int i = 0;i<name.size();i++){
if(name[i]==fn&&col[i]==n){
// cout<<fn<<" "<<count[i]<<endl;
count[i]++;
find = 1;
}
}
if(!find){
name.push_back(fn);
col.push_back(n);
count.push_back(1);
}
}
int i = name.size()>8?name.size()-8:0;
for(;i<name.size();i++){
cout<<name[i]<<" "<<col[i]<<" "<<count[i]<<endl;
}
return 0;
}
查看19道真题和解析
