Rezolvare completă PbInfo #2242 inserari

None

Cum e corect?

cout < "As la info"; cout << "As la info"; cout >> "As la info";

Felicitări! Poți mai mult?

Avem sute de probleme pentru tine, fiecare cu explicații ușor de înțeles.

Greșit, dar nu-i bai!

Antrenează-te cu sutele de probleme pe care ți le-am pregătit. Îți explicăm fiecare problemă în parte.

Rezolvare

Iată rezolvarea de 100 de puncte pentru problema inserari:

#include <iostream>
#define nmax 100002

using namespace std;

int a[nmax], lis[nmax], n, k;
// lis[i]=capatul minim al unui subsir de lungime i

void Citire()
{
    int i;
    cin >> n;
    for (i = 1; i <= n; i++)
        cin >> a[i];
}

// caut in lis[1..k] cea mai din stanga pozitie m cu x <= lis[m]
int CautBin(int x)
{
    int st, dr, sol, m;
    st = 1; dr = k;
    sol = k;
    while (st <= dr)
    {
        m = (st + dr) / 2;
        if (x <= lis[m])
        {
            sol = m;
            dr = m - 1;
        }
        else st = m + 1;
    }
    return sol;
}

int LIS()
{
    int i, x, p;
    lis[1] = a[1];
    k = 1;
    for (i = 2; i <= n; ++i)
    {
        x = a[i];
        if (x > lis[k]) lis[++k] = x;
        else if (x <= lis[1]) lis[1] = x;
        else
        {
            // caut in lis[1..k] cea mai din stanga pozitie p cu x <= lis[p]
            p = CautBin(x);
            lis[p] = x;
        }
    }
    return k;
}

void Afisare()
{
    int L;
    L = LIS();
    L = n - L;
    cout << L << "\n";
}

int main()
{
    Citire();
    Afisare();
    return 0;
}

Atenție

Enunțurile afișate pe această pagină aparțin exclusiv site-ului PbInfo. Astfel, pentru ștergerea conținutului, puteți să ne contactați la adresa Adresa de email.

Rezolvarea problemei #2242 inserari

Pe această pagină găsești rezolvarea de 100 de puncte pentru problema #2242 inserari de pe PbInfo.ro. Atenție: nu încurajăm copiatul codului! Totuși, credem cu tărie că analizarea unei soluții corecte este o metodă foarte ușoară de a învăța informatică, astfel că oferim sursele pentru peste 1500 de probleme de pe platforma PbInfo.ro.

Pentru rezolvări PbInfo de la peste 1500 de probleme, vă invităm să intrați pe site-ul nostru!