Rezolvare completă PbInfo #2132 min_subsir

Se consideră un șir de caractere format din litere mici ale alfabetului englez.

Cerința

Să se determine lungimea minimă a unei secvențe care conține toate literele întâlnite în șirul inițial.

Date de intrare

Programul citește de la tastatură șirul de caractere.

Date de ieșire

Programul va afișa pe ecran lungimea secvențele cerute.

Restricții și precizări

  • 1 ≤ lungime șir ≤ 10000

Exemplu

Intrare

aadcaabcbacadca

Ieșire

5

Explicație

Sunt folosite literele: a,b,c,d.
Secvențe de lungime minimă care folosesc toate literele: dcaab, bacad.

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 min_subsir:

#include <iostream>
#include <cstring>
using namespace std;

char s[10001];
bool ap[150];
int nr[10000],Min;

int main()
{
    int i,L,dist=0,j,k,L_sb;

    cin>>s;
    L=strlen(s);

    for(i=0;i<L;i++)
        if (!ap[(int)s[i]])
        {
            ap[(int)s[i]]=true;
            dist++; ///cate litere distincte avem
        }

    Min=L;
    k=j=0;
    for (i=0;i<L;i++)
    {
        nr[(int)s[i]]++;
        if (nr[(int)s[i]]==1) k++;
        if (k==dist)
        {
            ///determin lungimea subsirului
            while (nr[(int)s[j]]>1)
            {
                if (nr[(int)s[j]]>1) nr[(int)s[j]]--;
                j++;
            }
            L_sb=i-j+1;
            if (Min>L_sb)
            {
                Min=L_sb;
            }
        }
    }
    cout<<Min<<'\n';
    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 #2132 min_subsir

Pe această pagină găsești rezolvarea de 100 de puncte pentru problema #2132 min_subsir 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!