1101 Quick Sort

输入n个不同的数字,问有几个可以当快速排序的分割点pivot。输出个数以及是哪几个数字。左边要么没有要么都比pivot小,右边要么没有要么比pivot大。(题目中已经保证所有输入数字都不同)
pivot的位置与排序后的位置一致。(左小右大,分别排序左右即可,它不用动)并且要求pivot比左边最大的还大,比右边最小的还小。

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
35
36
37
#include <bits/stdc++.h>
using namespace std;

int res[100010];

int main() {
int n, cnt = 0, max = -1;
scanf("%d", &n);
vector<int> a(n), b(n);
for (int i = 0; i < n; i++) {
scanf("%d", &a[i]);
b[i] = a[i];
}
sort(a.begin(), a.end());
for (int i = 0; i < n; i++) {
if (a[i] == b[i] && b[i] > max) {
res[cnt++] = b[i];
}
if (b[i] > max) {
max = b[i];
}
}
printf("%d\n", cnt);
for (int i = 0; i < cnt; i++) {
if (i != 0) printf(" ");
printf("%d", res[i]);
}
printf("\n"); // 不加这个部分会出错

return 0;
}

5
1 3 2 4 5

3
1 4 5