蓝桥杯错误数据——运行超时(末尾文件结束)

 

一开始的代码,运行超时

复制代码
#include<iostream>
#include<cmath>
#include<cstdio>
#include<algorithm>
#include<string>
#include<cstring>
using namespace std;
int a[105];
int main()
{
   int n;
   cin>>n;
   int j=0;
   a[0]=0;    
   for(int i=0;i<n;i++)
   { 
      j++;
        cin>>a[j];
         while(cin.get()!='\n') 
         {
             j++;
             cin>>a[j];
      }
   }
   //有j个 
   sort(a,a+j+1);
   int shao=0;
   int duo=0;
   for(int i=1;i<j+1;i++)
   {
          if(a[i]==a[i+1])
          duo=a[i];
       if(i!=1&&i!=j&&(a[i]==a[i-1]+1)&&(a[i]==a[i+1]-2))
        shao=a[i]+1; 
   }
   cout<<shao<<" "<<duo<<endl;
   return 0;
 } 
复制代码

问题在于每行的结尾,在每行输入完后,你需要判断最后的字符是否为换行读取结束(EOF)

数据输入完毕,判断是否读取结束(EOF)

修改后

复制代码
#include<iostream>
#include<cmath>
#include<cstdio>
#include<algorithm>
#include<string>
#include<cstring>
using namespace std;
int a[105];
int main()
{
   int n;
   cin>>n;
   int j=0;
   while(cin>>a[j++]);
   //有j个 
   sort(a,a+j);
   int shao=0;
   int duo=0;
   for(int i=1;i<j;i++)
   {
          if(a[i]==a[i-1])
          duo=a[i-1];
     else//注意要把这个地方写上else,要不然重复的也会改变shao的值 
       if(a[i]!=a[i-1]+1)
        shao=a[i-1]+1; 
   }
   cout<<shao<<" "<<duo<<endl;
   return 0;
 } 
复制代码

 

posted @   Tomorrow1126  阅读(674)  评论(0编辑  收藏  举报
编辑推荐:
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· SQL Server 2025 AI相关能力初探
· 单线程的Redis速度为什么快?
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
点击右上角即可分享
微信分享提示