题目https://pintia.cn/problem-sets/994805260223102976/problems/994805278589960192
首先是min大小7个0不对,9个0才可以。
其二:格式问题,与下面正确代码对比没发现格式问题啊。不就是0和空格吗?数组定义没有问题。
在没有输入时依然要输出换行。所以我需要把两个输出的换行去掉,统一放到最后。这样第三个测试点就可以通过了。
#include<stdio.h>
int main(){
int n;
scanf("%d",&n);
int a[n],i;
for(i=0;i<n;i++){
scanf("%d",&a[i]);
}
int cnt=0,ans[n],min=1000000000,max=0;
int hashmin[100010]={0},hashmax[100010]={0};
for(i=0;i<n;i++){
if(a[i]>max) max=a[i];
hashmax[i]=max;
}
for(i=n-1;i>=0;i--){
if(a[i]<min) min=a[i];
hashmin[i]=min;
}
if(n==1) printf("1\n%d\n",a[0]);
else{
if(a[0]<hashmin[1]) ans[cnt++]=a[0];
for(i=1;i<n-1;i++){
if(a[i]<hashmin[i+1]&&a[i]>hashmax[i-1])
ans[cnt++]=a[i];
}
if(a[n-1]>hashmax[n-2]) ans[cnt++]=a[n-1];
printf("%d\n",cnt);
for(i=0;i<cnt;i++){
printf("%d",ans[i]);
if(i<cnt-1) printf(" ");
else printf("\n");
}
}
return 0;
}
正确代码:
#include<stdio.h>
#include<algorithm>
using namespace std;
int a[100010]={0},maxx[100010]={0},minn[100010]={0},ans[100010]={0};
int main(){
int i, n, max=0, min=1000000000;
scanf("%d",&n);
for(i=0;i<n;i++){
scanf("%d",&a[i]);
if(a[i]>max)max=a[i];
maxx[i]=max;
}
for(i=n-1;i>=0;i--){
if(a[i]<min)min=a[i];
minn[i]=min;
}
if(n==1){printf("1\n");printf("%d",a[0]);}
else{
int index=0;
if(a[0]<minn[1]){ans[index++]=a[0];}
for(i=1;i<n-1;i++){
if(a[i]>maxx[i-1]&&a[i]<minn[i+1]){ans[index++]=a[i];}
}
if(a[n-1]>maxx[n-2]){ans[index++]=a[i];}
printf("%d\n",index);
for(i=0;i<index;i++){
printf("%d",ans[i]);
if(i<index-1)printf(" ");
}
}
printf("\n");
return 0;
}
————————————————
版权声明:本文为CSDN博主「qq_2918」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_2918/article/details/79938117