Pagini recente » Cod sursa (job #266056) | Arhiva de probleme | Cod sursa (job #691878) | Istoria paginii runda/123-123/clasament | Cod sursa (job #3282445)
#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;
fin >> n;
vector<int> v(n + 1);
for (int i = 1; i <= n; i ++) {
fin >> v[i];
}
vector<int> rez = subir(v);
fout << rez.size() << '\n';
for (int num : rez) {
fout << num << " ";
}
return 0;
}