#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 | #51475233 | Utilizator | |
Fișier | mpf.cpp | Dimensiune | 2.16 KB |
Data încărcării | 24 Iunie 2024, 08:17 | Scor / rezultat | 100 puncte |
mpf.cpp: In function 'int rezolva()': mpf.cpp:155:41: warning: suggest parentheses around '&&' within '||' [-Wparentheses] if (fx[i]!=fy[i] || fx[i]==fy[i] && mx[i]!=my[i]) break; ^ mpf.cpp: In function 'int main()': mpf.cpp:59:17: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result] scanf("%d", &q); ^ mpf.cpp:69:29: 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.016 secunde | OK. | 5 | 5 | ||
2 | 0.016 secunde | OK. | 5 | 5 | ||
3 | 0.016 secunde | OK. | 5 | 5 | ||
4 | 0.016 secunde | OK. | 5 | 5 | ||
5 | 0.016 secunde | OK. | 5 | 5 | ||
6 | 0.016 secunde | OK. | 5 | 5 | ||
7 | 0.016 secunde | OK. | 5 | 5 | ||
8 | 0.016 secunde | OK. | 5 | 5 | ||
9 | 0.016 secunde | OK. | 10 | 10 | ||
10 | 0.016 secunde | OK. | 10 | 10 | ||
11 | 0.016 secunde | OK. | 10 | 10 | ||
12 | 0.092 secunde | OK. | 10 | 10 | ||
13 | 0.304 secunde | OK. | 10 | 10 | ||
14 | 0.336 secunde | OK. | 10 | 10 | ||
Punctaj total | 100 |
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ă.