华为OJ(简单错误记录)

描述

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

 

处理: 

 

1、 记录最多8条错误记录,循环记录,对相同的错误记录(净文件名称和行号完全匹配)只记录一条,错误计数增加;

 

2、 超过16个字符的文件名称,只记录文件的最后有效16个字符;

 

3、 输入的文件可能带路径,记录文件名称不能带路径。


知识点 字符串
运行时间限制 0M
内存限制 0
输入

一行或多行字符串。每行包括带路径文件名称,行号,以空格隔开。

 

如:E:\V1R2\product\fpgadrive.c   1325


输出

将所有的记录统计并将结果输出,格式:文件名 代码行数 数目,一个空格隔开,如:

 

 fpgadrive.c 1325 1


样例输入 E:\V1R2\product\fpgadrive.c 1325
样例输出 fpgadrive.c 1325 1
因为要求记录数不超过8个,循环计数,因此采用queue队列,超过8个,则对首pop,用map对每个键值计数。问题还真是多啊,最后还是都解决了。感觉对整个程序流程把握很重要!

<pre name="code" class="cpp">#include<iostream>
#include<queue>
#include<map>
#include<string>
using namespace std;
int main()
{
	string s,tmp,line;	
	map<string,int> imap;
	queue<string> sq;	
	int posleft,posright,len,spaceleft;
	while(cin>>s>>line)
	{
		posleft=s.find_last_of('\\');
		s=s.substr(posleft+1);	//将文件名求出		
		len=s.size();		
		if(len>16)
			tmp=s.substr(len-16,16)+" "+line;
		else
			tmp=s.substr(0,len)+" "+line;
		imap[tmp]++;
		if(imap[tmp]==1)
			sq.push(tmp);
		if(sq.size()>8)				
			//imap.erase(sq.front());问题出在这
			sq.pop();
		
		
	}

	while(!sq.empty())
	{
		cout<<sq.front()<<" "<<imap[sq.front()]<<endl;
		sq.pop();
	}
	//system("pause");
	return 0;
}


 下面基于未封装的类是OJ下面别的同学实现的,感觉体现了C++的类的思想,挺好的,也贴出来跟大家分享: 

#include<iostream>
#include<string>
#include<vector>
#include<algorithm>
using namespace std;

class record
{
      public:
      string name;
      int line;
      int count;
      record()
	  {
		  count = 1;
          name = "";
          line = -1;
     }
      void setName();
      bool query( record q );
      void output();
};
void record::setName()
{
      int pos = name.find( '\\') ;
      while( pos != string::npos )
      {
             name.erase( 0, pos + 1 );
             
             pos = name.find( '\\' );
             
       }//end while
}//end setName

bool record::query( record q )
{
     if( q.name == name && q.line == line )
     return true;
     
     return false;
     
}//end queryName

void record::output()
{
     int temp = name.length();
     
     //cout<<name.substr( temp - 16,16 )<<" "<<line<<" "<<count<<endl;
     if( name.length() <= 16 )
     cout<<name<<" "<<line<<" "<<count<<endl;
     else
     cout<<name.substr( temp - 16,16 )<<" "<<line<<" "<<count<<endl;
     
}
//end output


int main()
{    
    
    vector<record> input;
    string inputname;
    int line;
    while( cin>>inputname>>line )
    {
             //cin>>inputname>>line;
           record temp;
           temp.name = inputname;
           temp.line = line;
           temp.setName();
           
           if( !input.empty() )
           {
               bool query = false;
               
               for( int i = 0; i < input.size(); i++ )
                   if( input[ i ].query( temp ) )
                   {
                       query = true;
                       input[ i ].count++;
                       break;
                    } //end if
               
               if( !query )
               input.push_back( temp );
               
            }//end if
               else
               {
                  input.push_back( temp ); 
                }//end else
                   
   }//end while
    
    
    if( input.size() <= 8 )
       {
            for( int i = 0; i < input.size(); i++ )
            input[ i ].output();
        }//end if
    else
      {
         for( int i = input.size() - 8; i < input.size(); i++ )
               input[ i ].output();
      }//end else
    
    //system( "pause" );
    return 0;
    }//end main



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值