#4450
Un număr natural se numește extrapar dacă poate fi scris ca sumă de puteri distincte ale lui 2, puteri care au exponent par. Numărul 0 este considerat, de asemenea, extrapar. Considerând reprezentarea în baza 2 pentru un număr natural, se numerotează pozițiile cifrelor din reprezentare, de la dreapta către stânga, începând cu 0. Asupra reprezentării în baza 2 trebuie să se efectueze o singură operație. Operația constă din eliminarea a exact K cifre situate pe poziții consecutive. Fiind date reprezentările în baza 2 pentru N numere naturale, să se determine pentru fiecare dintre ele dacă se poate obține un număr extrapar în condițiile de mai sus.
ONI 2023 baraj juniori
| Problema | extrapare | Operații I/O |
extrapare.in/extrapare.out
|
|---|---|---|---|
| Limita timp | 0.3 secunde | Limita memorie |
Total: 128 MB
/
Stivă 64 MB
|
| Id soluție | #62742879 | Utilizator | |
| Fișier | extrapare.cpp | Dimensiune | 4.83 KB |
| Data încărcării | 31 Ianuarie 2026, 17:31 | Scor/rezultat | 100 puncte |
extrapare.cpp: In function 'int main()': extrapare.cpp:46:41: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] for (int i = 0; i <= s.size() - 1; i ++ ) { ^ extrapare.cpp:56:41: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] for (int i = 0; i <= s.size() - 1; i ++ ) { ^ extrapare.cpp:64:45: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] for (int i = 0; i <= s.size() - k; i ++) { ^ extrapare.cpp:66:39: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] if ((i+1 > s.size() - 1 || x[i+k] == 1) && ^ extrapare.cpp:78:55: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] for (int j = i+k; j <= s.size() - 1; j ++) { ^ extrapare.cpp:97:45: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] for (int i = 0; i <= s.size() - k; i ++) { ^ extrapare.cpp:99:39: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] if ((i+1 > s.size() - 1 || x[i+k] == 1) && ^ extrapare.cpp:111:55: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] for (int j = i+k; j <= s.size() - 1; j ++) { ^
| Test | Timp | Mesaj evaluare | Scor posibil | Scor obținut | ||
|---|---|---|---|---|---|---|
| 1 | 0.02 secunde | OK. | 5 | 5 | ||
| 2 | 0.016 secunde | OK. | 5 | 5 | ||
| 3 | 0.196 secunde | OK. | 7 | 7 | ||
| 4 | 0.004 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.192 secunde | OK. | 7 | 7 | ||
| 10 | 0 secunde | OK. | 4 | 4 | ||
| 11 | 0 secunde | OK. | 5 | 5 | ||
| 12 | 0.004 secunde | OK. | 5 | 5 | ||
| 13 | 0.02 secunde | OK. | 5 | 5 | ||
| 14 | 0 secunde | OK. | 1 | 1 | ||
| 15 | 0 secunde | OK. | 1 | 1 | ||
| 16 | 0 secunde | OK. | 1 | 1 | ||
| 17 | 0 secunde | OK. | 1 | 1 | ||
| 18 | 0 secunde | OK. | 1 | 1 | ||
| 19 | 0 secunde | OK. | 1 | 1 | ||
| 20 | 0 secunde | OK. | 2 | 2 | ||
| 21 | 0 secunde | OK. | 2 | 2 | ||
| 22 | 0 secunde | OK. | 2 | 2 | ||
| 23 | 0 secunde | OK. | 2 | 2 | ||
| 24 | 0 secunde | OK. | 2 | 2 | ||
| 25 | 0 secunde | OK. | 2 | 2 | ||
| 26 | 0 secunde | OK. | 2 | 2 | ||
| 27 | 0 secunde | OK. | 2 | 2 | ||
| 28 | 0 secunde | OK. | 2 | 2 | ||
| 29 | 0 secunde | OK. | 2 | 2 | ||
| 30 | 0 secunde | OK. | 2 | 2 | ||
| 31 | 0 secunde | OK. | 2 | 2 | ||
| 32 | 0 secunde | OK. | 2 | 2 | ||
| Punctaj total | 100 | |||||
www.pbinfo.ro permite evaluarea a două tipuri de probleme:
Problema extrapare 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ă.