-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathB1045.cpp
More file actions
34 lines (32 loc) · 718 Bytes
/
B1045.cpp
File metadata and controls
34 lines (32 loc) · 718 Bytes
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
#include <cstdio>
#include <algorithm>
using namespace std;
const int MAXN = 100000 + 10;
const int INF = 0x7fffffff;
int num[MAXN], leftMax[MAXN], rightMin[MAXN], ans[MAXN], N, cnt = 0;
int main(){
scanf("%d", &N);
for(int i = 0; i < N; ++i){
scanf("%d", &num[i]);
}
leftMax[0] = 0;
for(int i = 1; i < N; ++i){
leftMax[i] = max(leftMax[i-1], num[i-1]);
}
rightMin[N-1] = INF;
for(int i = N-2; i >=0; --i){
rightMin[i] = min(rightMin[i+1], num[i+1]);
}
for(int i = 0; i < N; ++i){
if(leftMax[i] < num[i] && rightMin[i] > num[i]){
ans[cnt++] = num[i];
}
}
printf("%d\n", cnt);
for(int i = 0; i < cnt; ++i){
printf("%d", ans[i]);
if(i != cnt-1) printf(" ");
}
printf("\n");
return 0;
}