题解 | #简单错误记录#
简单错误记录
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; }