#4609
opsir
Se consideră o pereche de șiruri de caractere, 𝑆
și 𝑇
, de lungime 𝑛
, respectiv 𝑚
, formate exclusiv din litere mici ale alfabetului englez. Pozițiile literelor sunt numerotate în șir începând de la 1
.
Sunt două tipuri de operații ce se pot efectua asupra șirului 𝑇
:
1 𝑝
: se șterge litera de pe poziția 𝑝
;2 𝑠𝑡 𝑑𝑟
(cu 𝑠𝑡 ≤ 𝑑𝑟
): se sortează crescător (alfabetic) literele din subsecvența ce corespunde intervalului de poziții [𝑠𝑡, 𝑑𝑟]
;unde 𝑝
, 𝑠𝑡
și 𝑑𝑟
sunt poziții ale unor litere din șirul 𝑇
.
Inițial, toate literele șirului 𝑇
sunt necolorate. O operație de tip 2 poate fi realizată doar dacă toate literele din subsecvența corespunzătoare intervalului de poziții [𝑠𝑡,𝑑𝑟]
sunt necolorate. După efectuarea sortării, toate literele din această subsecvență devin colorate.
Pentru fiecare dintre perechile de șiruri de tipul 𝑆
și 𝑇
date:
𝑆
sau 𝑇
) în care apare de mai multe ori. În caz de egalitate, se alege șirul 𝑇
.𝑇
, care să îl transforme𝑆
. Să se afișeze DA
în cazul în care există o astfel de succesiune de operații, sau NU
înOJI 2024, clasa a 10-a
Problema | opsir | Operații I/O |
opsir.in /opsir.out
|
---|---|---|---|
Limita timp | 0.5 secunde | Limita memorie |
Total: 128 MB
/
Stivă 8 MB
|
Id soluție | #53970638 | Utilizator | |
Fișier | opsir.cpp | Dimensiune | 2.45 KB |
Data încărcării | 16 Noiembrie 2024, 12:10 | Scor / rezultat | 100 puncte |
opsir.cpp: In function 'bool frecvente(int*, int*)': opsir.cpp:12:15: warning: array subscript has type 'char' [-Wchar-subscripts] if(S[c] > T[c]) ^ opsir.cpp:12:22: warning: array subscript has type 'char' [-Wchar-subscripts] if(S[c] > T[c]) ^ opsir.cpp: In function 'int main()': opsir.cpp:28:23: warning: array subscript has type 'char' [-Wchar-subscripts] S[s[j]]++; ^ opsir.cpp:30:23: warning: array subscript has type 'char' [-Wchar-subscripts] T[t[j]]++; ^ opsir.cpp:33:19: warning: array subscript has type 'char' [-Wchar-subscripts] if(S[c] != 0 || T[c] != 0) ^ opsir.cpp:33:32: warning: array subscript has type 'char' [-Wchar-subscripts] if(S[c] != 0 || T[c] != 0) ^ opsir.cpp:37:27: warning: array subscript has type 'char' [-Wchar-subscripts] if(S[c] > T[c]) ^ opsir.cpp:37:34: warning: array subscript has type 'char' [-Wchar-subscripts] if(S[c] > T[c]) ^ opsir.cpp:39:28: warning: array subscript has type 'char' [-Wchar-subscripts] else if(T[c] != 0) fout << c << " T\n"; ^ opsir.cpp:53:19: warning: array subscript has type 'char' [-Wchar-subscripts] S[s[0]]++; ^ opsir.cpp:57:27: warning: array subscript has type 'char' [-Wchar-subscripts] S[s[j]]++; ^ opsir.cpp:63:31: warning: array subscript has type 'char' [-Wchar-subscripts] T[t[h]]++; ^ opsir.cpp:71:32: warning: array subscript has type 'char' [-Wchar-subscripts] T[c] = 0; ^ opsir.cpp:75:28: warning: array subscript has type 'char' [-Wchar-subscripts] S[c] = 0; ^ opsir.cpp:76:27: warning: array subscript has type 'char' [-Wchar-subscripts] S[s[j]]++; ^
Test | Timp | Mesaj evaluare | Scor posibil | Scor obținut | ||
---|---|---|---|---|---|---|
1 | 0 secunde | OK. | 5 | 5 | ||
2 | 0 secunde | OK. | 5 | 5 | ||
3 | 0 secunde | OK. | 5 | 5 | ||
4 | 0 secunde | OK. | 5 | 5 | ||
5 | 0 secunde | OK. | 5 | 5 | ||
6 | 0 secunde | OK. | 5 | 5 | ||
7 | 0 secunde | OK. | 5 | 5 | ||
8 | 0 secunde | OK. | 5 | 5 | ||
9 | 0 secunde | OK. | 5 | 5 | ||
10 | 0 secunde | OK. | 5 | 5 | ||
11 | 0.008 secunde | OK. | 5 | 5 | ||
12 | 0.008 secunde | OK. | 5 | 5 | ||
13 | 0.008 secunde | OK. | 5 | 5 | ||
14 | 0.008 secunde | OK. | 5 | 5 | ||
15 | 0 secunde | OK. | 5 | 5 | ||
16 | 0 secunde | OK. | 5 | 5 | ||
17 | 0 secunde | OK. | 5 | 5 | ||
18 | 0 secunde | OK. | 5 | 5 | ||
19 | 0 secunde | OK. | 5 | 5 | ||
20 | 0 secunde | OK. | 5 | 5 | ||
Punctaj total | 100 |
www.pbinfo.ro permite evaluarea a două tipuri de probleme:
Problema opsir 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ă.