Cod sursa(job #3177412)

Utilizator mariaionescu2006Ionescu Maria mariaionescu2006 Data 29 noiembrie 2023 10:04:16
Problema Subsir crescator maximal Scor 15
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.82 kb
#include <iostream>
#include <fstream>
using namespace std;
ifstream fin ("scmax.in");
ofstream fout ("scmax.out");
int a[1001],n,d[1001],p[1001],in[1001],k;
int main()
{
    fin >>n;
    for (int i=1;i<=n;i++)
        {fin >>a[i];}
    k=1;
    d[k]=a[1];
    p[1]=1;
    for (int i=2;i<=n;i++)
        {if (a[i]>d[k]) {k++;d[k]=a[i];p[i]=k;}
         else {int st=1,dr=k,poz=k+1;
               while (st<=dr)
                     {int m=(st+dr)/2;
                      if (d[m]>=a[i]) {poz=m;dr=m-1;}
                      else st=m+1;}
               d[poz]=a[i];
               p[i]=poz;}}
    int j=n;
    for (int i=k;i>=1;i--)
        {while (p[j]!=i)
                j--;
         in[i]=j;}
    fout <<k<<'\n';
    for (int i=1;i<=k;i++)
    {
        fout <<d[i]<<' ';
    }
    return 0;
}