#4196
MPF
Fie X
un număr natural nenul și p
cel mai mare factor prim din descompunerea în factori primi a lui X
. Pentru X = 1
, considerăm p = 1
. Asupra lui X
se pot efectua următoarele două operații:
X
se împarte la p
și devine X / p
;X
devine X * k
, unde k
este un număr prim și mai mare sau egal decât p
.Se dau Q
perechi de numere naturale nenule (X, Y)
. Să se determine, pentru fiecare pereche, numărul minim de operații necesare pentru a-l transforma pe X
în Y
.
JBOI 2022
Problema | MPF | Operații I/O | tastatură/ecran |
---|---|---|---|
Limita timp | 0.5 secunde | Limita memorie |
Total: 256 MB
/
Stivă 64 MB
|
Id soluție | #37832740 | Utilizator | |
Fișier | mpf.cpp | Dimensiune | 2.85 KB |
Data încărcării | 21 Septembrie 2022, 19:51 | Scor / rezultat | 70 puncte |
mpf.cpp: In function 'int main()': mpf.cpp:32:82: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] for(int j = 0; 1LL * primes[j] * primes[j] <= 1LL * x && j < primes.size(); j++) { ^ mpf.cpp:46:82: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] for(int j = 0; 1LL * primes[j] * primes[j] <= 1LL * y && j < primes.size(); j++) { ^ mpf.cpp:59:54: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] for(int j = 0; j < min(pr1.size(), pr2.size());) { ^ mpf.cpp:85:51: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] for(int j = idx + 1; j < pr2.size(); j++) ^ mpf.cpp:90:47: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] for(int j = idx; j < pr2.size(); j++) ^ mpf.cpp:97:45: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] for(int j = 0; j < pr2.size(); j++) ^ mpf.cpp:101:45: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] for(int j = 0; j < pr1.size(); j++) ^ mpf.cpp:25:20: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result] scanf("%d", &q); ^ mpf.cpp:29:30: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result] scanf("%d%d", &x, &y); ^
Test | Timp | Mesaj evaluare | Scor posibil | Scor obținut | ||
---|---|---|---|---|---|---|
1 | 0.02 secunde | OK. | 5 | 5 | ||
2 | 0.02 secunde | OK. | 5 | 5 | ||
3 | 0.016 secunde | OK. | 5 | 5 | ||
4 | 0.02 secunde | OK. | 5 | 5 | ||
5 | 0.016 secunde | OK. | 5 | 5 | ||
6 | 0.02 secunde | OK. | 5 | 5 | ||
7 | 0.02 secunde | OK. | 5 | 5 | ||
8 | 0.016 secunde | OK. | 5 | 5 | ||
9 | 0.016 secunde | OK. | 10 | 10 | ||
10 | 0.02 secunde | OK. | 10 | 10 | ||
11 | 0.02 secunde | OK. | 10 | 10 | ||
12 | 0.176 secunde | Raspuns gresit. | 10 | 0 | ||
13 | Depășit | Limita de timp depășită | 10 | 0 | ||
14 | Depășit | Limita de timp depășită | 10 | 0 | ||
Punctaj total | 70 |
www.pbinfo.ro permite evaluarea a două tipuri de probleme:
Problema MPF 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ă.