【牛客网】简单错误记录

题目描述

开发一个简单错误记录功能小模块,能够记录出错的代码所在的文件名称和行号。
处理:
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
欢迎大家留言讨论,希望能找到解决办法。。。

  • 4
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
LeetCode和牛客网都是在线编程练习平台,供程序员进行算法和编程题目的练习。两个平台有一些区别。 LeetCode是一个以算法为主的平台,题目描述简练,直奔主题,通常使用英文进行描述。LeetCode注重算法思维和解题能力的锻炼,题目更偏向于算法和数据结构的应用。许多人在LeetCode上进行练习,习惯了它的题目风格和解题模式。 而牛客网是一个综合性的在线编程平台,除了算法题,还包括面试题、笔试题、实习生项目等。牛客网的题目描述相对LeetCode来说更加贴近实际场景,有更多的描述和背景信息。这也可能导致牛客网的题目相对较长,需要花费一些时间来阅读和理解。 不同的人对于这两个平台的喜好和适应程度各有差异。有的人可能习惯于LeetCode的简练风格,而对牛客网的题目描述感到吃力;有的人则喜欢牛客网提供的更多背景和场景信息。 总的来说,LeetCode和牛客网都是很好的编程练习平台,可以根据个人的需要和喜好进行选择和使用。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [LeetCode和牛客网的对比](https://blog.csdn.net/zr1076311296/article/details/51606300)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值