/**
* 1.解题思路:对原序列sort排序,逐个比较
* 当当前元素没有变化并且它左边的所有值的最大值都比它小的时候就可以认为它一定是主元
*
* 2.参考博客:https://www.liuchuo.net/archives/505
*/
#include <iostream>
#include <algorithm>
#include <vector>
int v[100000];
using namespace std;
int main() {
int n, max = 0, cnt = 0;
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++) {
//判断当前元素是否有变化
//max为左边最大元素值
if(a[i] == b[i] && b[i] > max)
v[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", v[i]);
}
printf("\n");
return 0;
}
1045 快速排序
最新推荐文章于 2021-01-10 08:48:50 发布