Pagini recente » Cod sursa (job #676168) | Cod sursa (job #704567) | Cod sursa (job #184957) | Cod sursa (job #1704532) | Cod sursa (job #2177438)
#include <bits/stdc++.h>
using namespace std;
ifstream fin("scmax.in");
ofstream fout("scmax.out");
int A[100003], B[100003], C[100003], D[100003], i,p,n,j;
int main(){
fin>>n;
for (i=1; i<=n; i++){
fin>>A[i];
}
C[n]=1;
D[n]=0;
for (i=n-1; i>=1; i--)
{
p=i;
C[i]=0;
for(j=i+1; j<=n; j++)
{
if ((A[i]<A[j]) && (C[j]>C[p]))
p=j;
}
C[i]=C[p]+1;
if(p!=i){
D[i]=p;
}
else D[i]=0;
}
p=n;
for (i=n-1; i>=1; i--)
if(C[i]>C[p]) p=i;
fout<<C[p]<<endl;
fout<<A[p]<<" ";
p=D[p];
while (p) {
fout<<A[p]<<" ";
p=D[p];
}
return 0;
}