一、技术总结

  1. 这里的一个关键就是理解调换位置排序是时,如果是元主,那么它要确保的条件就只有两个一个是,自己的位置不变,还有就是前面的元素不能有比自己大的。

    二、参考代码

#include<iostream>
#include<algorithm>
#include<vector>
using namespace std;
int record[100000];
int main(){
    int n, max = 0, count = 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++){
        if(a[i] == b[i] && b[i] > max){
            record[count++] = a[i];
        }
        if(b[i] > max) max = b[i];
    }
    printf("%d\n", count);
    for(int i = 0; i < count; i++){
        if(i != 0) printf(" ");
        printf("%d", record[i]);
    }
    printf("\n");
    return 0;


}
01-13 10:29