#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 | #53496773 | Utilizator | |
Fișier | opsir.cpp | Dimensiune | 1.58 KB |
Data încărcării | 02 Noiembrie 2024, 22:05 | Scor / rezultat | 100 puncte |
opsir.cpp: In function 'int frecv(int*, int*)': opsir.cpp:12:15: warning: array subscript has type 'char' [-Wchar-subscripts] if(T[i]<S[i]) return 0; ^ opsir.cpp:12:20: warning: array subscript has type 'char' [-Wchar-subscripts] if(T[i]<S[i]) return 0; ^ opsir.cpp: In function 'void verif(int, int, int&, int&)': opsir.cpp:21:15: warning: array subscript has type 'char' [-Wchar-subscripts] S[s[i]]++; ^ opsir.cpp:24:15: warning: array subscript has type 'char' [-Wchar-subscripts] T[t[j]]++; ^ opsir.cpp: In function 'int main()': opsir.cpp:41:23: warning: array subscript has type 'char' [-Wchar-subscripts] S[s[i]]++; ^ opsir.cpp:43:23: warning: array subscript has type 'char' [-Wchar-subscripts] T[t[i]]++; ^ opsir.cpp:45:23: warning: array subscript has type 'char' [-Wchar-subscripts] if(S[i]+T[i]>0) c++; ^ opsir.cpp:45:28: warning: array subscript has type 'char' [-Wchar-subscripts] if(S[i]+T[i]>0) c++; ^ opsir.cpp:48:23: warning: array subscript has type 'char' [-Wchar-subscripts] if(S[i]+T[i]>0) ^ opsir.cpp:48:28: warning: array subscript has type 'char' [-Wchar-subscripts] if(S[i]+T[i]>0) ^ opsir.cpp:50:27: warning: array subscript has type 'char' [-Wchar-subscripts] if(T[i]>=S[i]) cout<<i<<" T\n"; ^ opsir.cpp:50:33: warning: array subscript has type 'char' [-Wchar-subscripts] if(T[i]>=S[i]) cout<<i<<" T\n"; ^
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.004 secunde | OK. | 5 | 5 | ||
12 | 0.004 secunde | OK. | 5 | 5 | ||
13 | 0.004 secunde | OK. | 5 | 5 | ||
14 | 0.004 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ă.