题解 | #简单错误记录#

简单错误记录

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;
}


#华为#
全部评论

相关推荐

把实习生当正职使昨天第一天就加班,晚上连口饭都没吃上,以后日子咋过,我不想干了
码农索隆:实习不怕忙,就怕干的活重复且没难度,要干就干那种有深度有难度的任务,这样才能快速的提升
点赞 评论 收藏
分享
05-05 21:45
已编辑
广州大学 Java
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务