#1133
Charlie a decis să se joace cu literele dintr-un șir de caractere, șir ce conține doar literele mici ale alfabetului englez ’a’…’z’. Jocul constă în a elimina litere din șir după următoarea regulă: fie L1, L2, L3 trei litere aflate pe poziții consecutive în șir, atunci litera L2 poate fi eliminată dacă și numai dacă este strict mai mică lexicografic decât literele L1 și L3.
Pentru a face jocul mai interesant, Charlie atașează eliminării literei L2 un cost egal cu valoarea maximă dintre ō(L1) și ō(L3), unde prin ō(litera) înțelegem numărul de ordine al literei respective în alfabet (ō(’a’)=1, ō(’b’)=2,…, ō(’z’)=26). Charlie aplică în mod repetat procedeul de eliminare și calculează suma costurilor eliminărilor efectuate.
Fiind dat un șir de caractere să se determine:
a) Lungimea maximă a unei secvențe de litere alternante, adică o secvență pentru care literele aflate pe poziții consecutive sunt de forma: Li > Li+1 < Li+2 > Li+3 < Li+4 > … < Lj.
b) Suma maximă pe care o poate obține Charlie aplicând în mod repetat procedeul de eliminare a literelor, precum și șirul obținut în final.
| Problema | Charlie | Operații I/O |
charlie.in/charlie.out
|
|---|---|---|---|
| Limita timp | 0.5 secunde | Limita memorie |
Total: 4 MB
/
Stivă 2 MB
|
| Id soluție | #64791664 | Utilizator | |
| Fișier | charlie.cpp | Dimensiune | 1.49 KB |
| Data încărcării | 01 Iunie 2026, 12:53 | Scor/rezultat | 25 puncte |
charlie.cpp: In function ‘void afis(std::vector<int>)’: charlie.cpp:6:19: warning: comparison of integer expressions of different signedness: ‘int’ and ‘std::vector<int>::size_type’ {aka ‘long unsigned int’} [-Wsign-compare] 6 | for(int i=0; i<stiva.size(); i++) | ~^~~~~~~~~~~~~ charlie.cpp: In function ‘int main()’: charlie.cpp:62:23: warning: comparison of integer expressions of different signedness: ‘int’ and ‘std::vector<int>::size_type’ {aka ‘long unsigned int’} [-Wsign-compare] 62 | for(int i=0; i<stiva.size(); i++) | ~^~~~~~~~~~~~~ charlie.cpp:19:9: warning: unused variable ‘l’ [-Wunused-variable] 19 | int l,l_max=-1,n=int(s.size()); | ^
| Test | Timp | Mesaj evaluare | Scor posibil | Scor obținut | ||
|---|---|---|---|---|---|---|
| 0 | 0.001 secunde | OK. | 5 | 5 | ||
| 1 | 0.001 secunde | OK. | 5 | 5 | ||
| 2 | 0.001 secunde | OK. | 5 | 5 | ||
| 3 | 0.002 secunde | OK. | 5 | 5 | ||
| 4 | 0.06 secunde | OK. | 5 | 5 | ||
| 5 | 0.001 secunde | Raspuns gresit. | 4 | 0 | ||
| 6 | 0.001 secunde | Raspuns gresit. | 5 | 0 | ||
| 7 | 0.001 secunde | Raspuns gresit. | 5 | 0 | ||
| 8 | 0.003 secunde | Raspuns gresit. | 5 | 0 | ||
| 9 | 0.003 secunde | Raspuns gresit. | 5 | 0 | ||
| 10 | 0.004 secunde | Raspuns gresit. | 5 | 0 | ||
| 11 | 0.003 secunde | Raspuns gresit. | 5 | 0 | ||
| 12 | 0.003 secunde | Raspuns gresit. | 5 | 0 | ||
| 13 | 0.003 secunde | Raspuns gresit. | 5 | 0 | ||
| 14 | 0.002 secunde | Raspuns gresit. | 5 | 0 | ||
| 15 | 0.005 secunde | Raspuns gresit. | 5 | 0 | ||
| 16 | 0.002 secunde | Raspuns gresit. | 5 | 0 | ||
| 17 | 0.003 secunde | Raspuns gresit. | 6 | 0 | ||
| 18 | 0.002 secunde | Raspuns gresit. | 6 | 0 | ||
| 19 | 0.001 secunde | Raspuns gresit. | 4 | 0 | ||
| Punctaj total | 25 | |||||
www.pbinfo.ro permite evaluarea a două tipuri de probleme:
Problema Charlie face parte din prima categorie. Soluția propusă de tine va fi evaluată astfel:
Suma punctajelor acordate pe testele utilizate pentru verificare este 100. Astfel, soluția ta poate obține cel mult 100 de puncte, caz în care se poate considera corectă.