#2153
Mirror
Numim „oglinda” numărului natural nenul a
, numărul b
, obţinut prin modificarea fiecărei cifre din reprezentarea sa binară, de exemplu pentru a=22
(10)
=10110
(2)
se obţine 01001
(2)
= 9
(10)
=b
.
Cunoscându-se numerele naturale N
, K
și cele N
numere natural nenule, scrieți un program care:
10
corespunzătoare secvenţelor alăturate de exact K
cifre binare, parcurse de la stânga la drepta. Dacă ultima secvenţă nu are exact K
cifre binare, atunci aceasta nu se va mai lua în considerare.K
transformări asupra şirului iniţial, înlocuind la fiecare pas orice termen cu „oglinda” sa. Asupra termenilor care devin zero nu se vor mai efectua alte operații. După efectuarea celor K
transformări, să se determine cea mai lungă secvență de numere care au cifra 1
pe aceeași poziție în reprezentarea lor în baza doi. Dacă sunt mai multe astfel de secvențe având lungimea maximă, se va afișa cea mai din stânga.Problema | Mirror | Operații I/O |
mirror.in /mirror.out
|
---|---|---|---|
Limita timp | 0.3 secunde | Limita memorie |
Total: 32 MB
/
Stivă 32 MB
|
Id soluție | #42980284 | Utilizator | |
Fișier | mirror.cpp | Dimensiune | 2.95 KB |
Data încărcării | 25 Martie 2023, 12:32 | Scor / rezultat | 100 puncte |
mirror.cpp: In function 'int main()': mirror.cpp:49:39: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] for (i = 0; i < cif2.size() / 2; i++) { ^ mirror.cpp:52:37: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] for (i = k-1; i < cif2.size(); i += k) { ^
Test | Timp | Mesaj evaluare | Scor posibil | Scor obținut | ||
---|---|---|---|---|---|---|
0 | 0 secunde | OK. | 10 | 10 | ||
1 | 0 secunde | OK. | 10 | 10 | ||
2 | 0 secunde | OK. | 10 | 10 | ||
3 | 0 secunde | OK. | 10 | 10 | ||
4 | 0.004 secunde | OK. | 10 | 10 | ||
5 | 0.124 secunde | OK. | 10 | 10 | ||
6 | 0.008 secunde | OK. | 10 | 10 | ||
7 | 0.04 secunde | OK. | 10 | 10 | ||
8 | 0.072 secunde | OK. | 10 | 10 | ||
9 | 0 secunde | OK. | 10 | 10 | ||
Punctaj total | 100 |
www.pbinfo.ro permite evaluarea a două tipuri de probleme:
Problema Mirror 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ă.