#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 | #59284689 | Utilizator | |
| Fișier | anagrame6.cpp | Dimensiune | 3.71 KB |
| Data încărcării | 24 Septembrie 2025, 00:21 | Scor/rezultat | 100 puncte |
anagrame6.cpp: In function 'int comp(std::vector<P>&, std::vector<P>&)': anagrame6.cpp:99:30: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] for (int i = 0; i < a.size() && i < b.size(); i++) { ^ anagrame6.cpp:99:46: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] for (int i = 0; i < a.size() && i < b.size(); i++) { ^ anagrame6.cpp:100:41: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] if (a[i].comp(b[i], i == a.size() - 1 || i == b.size() - 1) != 0) ^ anagrame6.cpp:100:62: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] if (a[i].comp(b[i], i == a.size() - 1 || i == b.size() - 1) != 0) ^ anagrame6.cpp:101:46: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] return a[i].comp(b[i], i == a.size() - 1 || i == b.size() - 1); ^ anagrame6.cpp:101:67: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] return a[i].comp(b[i], i == a.size() - 1 || i == b.size() - 1); ^ anagrame6.cpp: In function 'int main()': anagrame6.cpp:115:37: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)', declared with attribute warn_unused_result [-Wunused-result] freopen("anagrame.in", "r", stdin); ^ anagrame6.cpp:116:39: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)', declared with attribute warn_unused_result [-Wunused-result] freopen("anagrame.out", "w", stdout); ^ anagrame6.cpp:118:32: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result] scanf("%d%d%d\n", &p, &n, &m); ^ anagrame6.cpp:137:30: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result] scanf("%d%d\n", &a, &b); ^ anagrame6.cpp:164:26: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result] scanf("%d\n", &pos); ^
| Test | Timp | Mesaj evaluare | Scor posibil | Scor obținut | ||
|---|---|---|---|---|---|---|
| 1 | 0.06 secunde | OK. | 4 | 4 | ||
| 2 | 0.06 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.364 secunde | OK. | 4 | 4 | ||
| 8 | 0.008 secunde | OK. | 4 | 4 | ||
| 9 | 0 secunde | OK. | 4 | 4 | ||
| 10 | 0.076 secunde | OK. | 4 | 4 | ||
| 11 | 0.072 secunde | OK. | 4 | 4 | ||
| 12 | 0.056 secunde | OK. | 4 | 4 | ||
| 13 | 0.656 secunde | OK. | 4 | 4 | ||
| 14 | 0.664 secunde | OK. | 4 | 4 | ||
| 15 | 0.652 secunde | OK. | 4 | 4 | ||
| 16 | 0.18 secunde | OK. | 4 | 4 | ||
| 17 | 0.176 secunde | OK. | 4 | 4 | ||
| 18 | 0.044 secunde | OK. | 4 | 4 | ||
| 19 | 0.044 secunde | OK. | 4 | 4 | ||
| 20 | 0.044 secunde | OK. | 4 | 4 | ||
| 21 | 0.192 secunde | OK. | 4 | 4 | ||
| 22 | 0.192 secunde | OK. | 4 | 4 | ||
| 23 | 0.684 secunde | OK. | 4 | 4 | ||
| 24 | 0.688 secunde | OK. | 4 | 4 | ||
| 25 | 0.68 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ă.