#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 | #62745240 | Utilizator | |
| Fișier | anagrame6.cpp | Dimensiune | 3.72 KB |
| Data încărcării | 31 Ianuarie 2026, 19:38 | Scor/rezultat | Eroare de compilare |
anagrame6.cpp: In function 'long long int modexp(long long int, long long int)': anagrame6.cpp:73:28: error: expected primary-expression before '__int128' if(exp & 1) res = (__int128)res * base % MOD; ^ anagrame6.cpp:73:28: error: expected ')' before '__int128' anagrame6.cpp:74:17: error: expected primary-expression before '__int128' base = (__int128)base * base % MOD; ^ anagrame6.cpp:74:17: error: expected ')' before '__int128' anagrame6.cpp: In function 'int main()': anagrame6.cpp:133:33: error: expected primary-expression before '__int128' ways = (__int128)ways * invFact[cnt[i]] % MOD; ^ anagrame6.cpp:133:33: error: expected ')' before '__int128'
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ă.