• 技术文章 >后端开发 >C#.Net教程

    C++笔试题之实现简单记录错误功能

    little bottlelittle bottle2019-04-24 14:52:05转载1481
    本篇文章,小编将和大家分享一个有意思的C++笔试题,要求实现简单错误记录的功能,感兴趣的朋友可以了解一下,希望能对你的C++开发学习有所帮助。

    题目介绍:

    开发一个简单错误记录功能小模块,能够记录出错的代码所在的文件名称和行号。 要求:

    1.记录最多8条错误记录,对相同的错误记录(即文件名称和行号完全匹配)只记录一条,错误计数增加;(文件所在的目录不同,文件名和行号相同也要合并);

    2.超过16个字符的文件名称,只记录文件的最后有效16个字符;(如果文件名不同,而只是文件名的后16个字符和行号相同,也不要合并);

    3.输入的文件可能带路径,记录文件名称(只记录文件名)不能带路径 。

    例:

    输入:

    E:\\linuas\\desktop\\demo.txt 1234

    E:\\linuas\\desktop\\demo.doc 1234

    E:\\linuas\\desktop\\demo.txt 1234

    输出:

    demo.txt 1234 2

    demo.doc 1234 1

    分析:

    解决方案里用到了pair(包含两种格式的数据结构)、make_pair(构造pair)、vector(栈)、find(找到字符串中指定字符位置)、erase(删除部分字符串)、substr(截取字符串)等用法,值得记录一下,免得后期学习忘记。解决方案高效而使用,不可多得。

    #include <iostream>
    #include <vector>
    #include <string>
    #include <algorithm>
    using namespace std;
    bool compare(pair<string, int> a, pair<string, int> b) {
        return a.second > b.second;
    }
    int main(void) {
        string input, file;
        vector<pair<string, int>> errors;
        while (getline(cin, input)) {
            if (input.size() == 0)
                break;
            unsigned int f = input.rfind('\\');
            file = input.substr(f + 1);
            errors.push_back(make_pair(file, 1));
            for (int i = 0; i<(errors.size() - 1); i++) {
                if (errors[i].first == file) {
                    errors[i].second++;
                    errors.pop_back(); break;
                }
            }
        }
        stable_sort(errors.begin(), errors.end(), compare);
        int idx = 0;
        while (idx<8 && idx<errors.size()) {
            string check = errors[idx].first;
            int t = check.find(' ');
            if (t>16)
                errors[idx].first.erase(0, t - 16);
            cout << errors[idx].first << ' ' << errors[idx].second << endl;
            idx++;
        }
    }

    结果:

    php入门到就业线上直播课:进入学习

    相关教程:C++视频教程

    以上就是C++笔试题之实现简单记录错误功能的详细内容,更多请关注php中文网其它相关文章!

    声明:本文转载于:博客园,如有侵犯,请联系admin@php.cn删除

    前端(VUE)零基础到就业课程:点击学习

    清晰的学习路线+老师随时辅导答疑

    自己动手写 PHP MVC 框架:点击学习

    快速了解MVC架构、了解框架底层运行原理

    专题推荐:C++ 错误记录
    上一篇:c++输出二维字符矩阵对齐 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • ❤️‍🔥共22门课程,总价3725元,会员免费学• ❤️‍🔥接口自动化测试不想写代码?• Oracle实现对表dml错误记录日志• Python中数据结构与算法的应用(附示例)• c语言递归算法怎么实现• c语言如何实现选择排序算法(代码示例)
    1/1

    PHP中文网