Pagini recente » Cod sursa (job #2366828) | Cod sursa (job #2044533) | Cod sursa (job #2071204) | Cod sursa (job #1318558) | Cod sursa (job #3321569)
#include<bits/stdc++.h>
using namespace std;
ifstream fin("scmax.in");
ofstream fout("scmax.out");
int best[100002], n, v[100002], tata[100002];
void afis(int p){
if(p){
afis(tata[p]);
fout << v[p] << " ";
}
}
int main(){
int i,mx,ans=0,j,p;
fin >> n;
for(i=1;i<=n;i++)
fin >> v[i];
for(i=1;i<=n;i++){
mx=0;
for(j=1;j<i;j++){
if(v[i] > v[j]){
if(mx < best[j]){
mx = best[j];
tata[i] = j;
}
}
}
best[i] = 1+mx;
if(best[i] > ans){
ans = best[i];
p = i;
}
}
fout << ans << '\n';
afis(p);
}