#4815
Se consideră șirul de litere mici ale alfabetului englez A[1], ..., A[N]
.
Fie succesiunea de caractere alăturate din șir A[x], A[x + 1], ..., A[y]
, unde 1 ≤ x ≤ y ≤ N
, pe care o notăm cu A[x, y]
. Pentru oricare literă mică a alfabetului englez l
, definim range(l)
ca fiind 0
, dacă l
apare cel mult o dată în A[x, y]
. Altfel, valoarea range(l)
este egală cu diferența dintre cea mai mare și cea mai mică poziție pe care litera l
apare în A[x, y]
.
Șirul suport asociat lui A[x, y]
este șirul de caractere minim lexicografic ce conține fiecare literă l
de range(l)
ori. Asupra șirului se efectuează două tipuri de operații:
c
și poziția poz
, se înlocuiește A[poz]
cu c
.x, y
, se generează șirul suport al lui A[x, y]
.C = 1
: determinați șirul suport minim lexicografic dintre cele obținute în urma tuturor operațiilor de generare.C = 2
: pentru fiecare operație de generare dată, determinați numărul de anagrame distincte ale șirului suport obținut, modulo 1999999973
.Problema | anagrame6 | Operații I/O |
![]() anagrame.in /anagrame.out
|
---|---|---|---|
Limita timp | 1 secunde | Limita memorie |
Total: 256 MB
/
Stivă 64 MB
|
Id soluție | #57795291 | Utilizator | |
Fișier | anagrame6.cpp | Dimensiune | 3.75 KB |
Data încărcării | 16 Aprilie 2025, 19:23 | Scor / rezultat | 100 puncte |
anagrame6.cpp: In function 'int getInt(std::string)': anagrame6.cpp:76:32: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] for (int i = 1; i < x.size(); ++i) { ^
Test | Timp | Mesaj evaluare | Scor posibil | Scor obținut | ||
---|---|---|---|---|---|---|
1 | 0.108 secunde | OK. | 4 | 4 | ||
2 | 0.108 secunde | OK. | 4 | 4 | ||
3 | 0 secunde | OK. | 4 | 4 | ||
4 | 0 secunde | OK. | 4 | 4 | ||
5 | 0 secunde | OK. | 4 | 4 | ||
6 | 0 secunde | OK. | 4 | 4 | ||
7 | 0.36 secunde | OK. | 4 | 4 | ||
8 | 0.012 secunde | OK. | 4 | 4 | ||
9 | 0 secunde | OK. | 4 | 4 | ||
10 | 0.116 secunde | OK. | 4 | 4 | ||
11 | 0.116 secunde | OK. | 4 | 4 | ||
12 | 0.104 secunde | OK. | 4 | 4 | ||
13 | 0.416 secunde | OK. | 4 | 4 | ||
14 | 0.4 secunde | OK. | 4 | 4 | ||
15 | 0.412 secunde | OK. | 4 | 4 | ||
16 | 0.12 secunde | OK. | 4 | 4 | ||
17 | 0.12 secunde | OK. | 4 | 4 | ||
18 | 0 secunde | OK. | 4 | 4 | ||
19 | 0 secunde | OK. | 4 | 4 | ||
20 | 0 secunde | OK. | 4 | 4 | ||
21 | 0.136 secunde | OK. | 4 | 4 | ||
22 | 0.136 secunde | OK. | 4 | 4 | ||
23 | 0.712 secunde | OK. | 4 | 4 | ||
24 | 0.704 secunde | OK. | 4 | 4 | ||
25 | 0.716 secunde | OK. | 4 | 4 | ||
Punctaj total | 100 |
www.pbinfo.ro permite evaluarea a două tipuri de probleme:
Problema anagrame6 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ă.