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 .
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!