题目描述
开发一个简单错误记录功能小模块,能够记录出错的代码所在的文件名称和行号。
处理:
1、 记录最多8条错误记录,循环记录,对相同的错误记录(净文件名称和行号完全匹配)只记录一条,错误计数增加;
2、 超过16个字符的文件名称,只记录文件的最后有效16个字符;
3、 输入的文件可能带路径,记录文件名称不能带路径。
输入描述:
一行或多行字符串。每行包括带路径文件名称,行号,以空格隔开。
输出描述:
将所有的记录统计并将结果输出,格式:文件名 代码行数 数目,一个空格隔开
示例
输入
E:\V1R2\product\fpgadrive.c 1325
输出
fpgadrive.c 1325 1
解题思路
我的思路是从输入的文件路径中提取出文件名,再将它和错误行及空格三部分组成字符串,用map完成计数存储。
代码没错误,但是思路与牛客网的要求不太一致,导致代码没法通过!!
通过代码运行得到测试用例,我猜想我的错误主要在输出部分。
牛客网上的要求是希望所有错误都能输入并记录,但只输出最后输入的8个错误。而我的代码会在输入第九个用例的时候直接退出并输出前8个错误,而且我忘记map会对key值进行排序,,,然后我就去改了代码,最后的最后我还是没有改好。。。
如果有看出解决办法的大佬麻烦指点我一下,我真的很需要帮助~
完整代码
#include <iostream>
#include <map>
#include <string>
#include <algorithm>
using namespace std;
string iToS(int n) //整型转字符串
{
string s;
int a = n % 10;
s.push_back(a + '0');
n /= 10;
while (n)
{
a = n % 10;
s.push_back(a + '0');
n /= 10;
}
reverse(s.begin(), s.end());
return s;
}
string getFile(string s, int n) //获取文件名,同时将行数放在字符串中
{
string s1;
int i = 0;
int pos = s.find('\\', i);
while (pos<s.size()) //找到最后一个\,记录此时i
{
i = pos + 1;
pos = s.find('\\', i);
}
for (i; i < s.size(); i++) //用s1记录文件名
s1.push_back(s[i]);
if (s1.size()>16) //如果文件名字符大于16则只取后16位
s1 = s1.substr(s1.size() - 16, 16);
s1.push_back(' ');
string s2 = iToS(n);
s1 += s2;
return s1;
}
int main()
{
string s;
int n;
map<string, int> m;
int k = 0;
while (cin >> s >> n) //循环输入
{
string s1 = getFile(s, n); //将输入转成一个字符串
auto ret = m.insert(make_pair(s1, 1)); //所有数据插入map中
if (!ret.second) //如果字符串已经存在则计数加一
ret.first->second += 1;
if (m.size()>8) //如果map的有效个数大于8,则删除最后一个插入的数据并跳出循环
{
m.erase(s1);
break;
}
}
for (auto &e : m) //输出map中数据
cout << e.first << " " << e.second << " ";
system("pause");
return 0;
}
原题链接:
https://www.nowcoder.com/questionTerminal/2baa6aba39214d6ea91a2e03dff3fbeb
欢迎大家留言讨论,希望能找到解决办法。。。