第一次参加PAT考试,遇到的第二道题,感觉很简单,但是智商余额不足,导致最后只想出来遍历的方法,还有一个陷阱是如果数据为0也要输出一个空行。最笨的方法也能得20分,只能说真给面子了。
看了大神们的代码,从前往后遍历,记录最大值,从后往前遍历,记录最小值,然后比较。
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
using namespace std;
int n;
int a[100003];
int b[100003];
int main()
{
while(scanf("%d",&n) != EOF)
{
for(int i = 0; i < n; i++)
scanf("%d",&a[i]);
bool flag[100003];
memset(flag,true,sizeof(flag));
int maxNum = a[0];
for(int i = 0; i < n; i++)
{
if(a[i] < maxNum)
flag[i] = false;
else
maxNum = a[i];
}
int minNum = a[n-1];
for(int i = n-1; i >= 0; i--)
{
if(a[i] > minNum)
flag[i] = false;
else
minNum = a[i];
}
int num = 0;
for(int i = 0; i < n; i++)
if(flag[i] == true)
b[num++] = a[i];
sort(b,b+num);
printf("%d\n",num);
for(int i = 0; i < num; i++)
{
if(i != 0)
printf(" ");
printf("%d",b[i]);
}
printf("\n");
}
return 0;
}
202

被折叠的 条评论
为什么被折叠?



