Pagini recente » Cod sursa (job #1501960) | Cod sursa (job #706024) | Cod sursa (job #2230031) | Cod sursa (job #1511689) | Cod sursa (job #3282446)
#include <iostream>
#include <vector>
#include <algorithm>
#include <fstream>
using namespace std;
ifstream fin("scmax.in");
ofstream fout("scmax.out");
vector<int> subir(vector<int>& v) {
vector<int> subsir;
for (int numar : v) {
auto iterator = lower_bound(subsir.begin(), subsir.end(), numar);
if (iterator == subsir.end()) {
subsir.push_back(numar);
} else {
*iterator = numar;
}
}
return subsir;
}
int main() {
int n;
cin >> n;
vector<int> v(n);
for (int i = 0; i < n; i ++) {
cin >> v[i];
}
vector<int> rez = subir(v);
cout << rez.size() << '\n';
for (int num : rez) {
cout << num << " ";
}
return 0;
}