#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 | #50712526 | Utilizator | |
Fișier | mpf.cpp | Dimensiune | 1.75 KB |
Data încărcării | 23 Aprilie 2024, 20:53 | Scor / rezultat | Eroare de compilare |
mpf.cpp:68:2: error: stray '\302' in program return rez; ^ mpf.cpp:68:2: error: stray '\240' in program mpf.cpp:68:2: error: stray '\302' in program mpf.cpp:68:2: error: stray '\240' in program mpf.cpp:68:2: error: stray '\302' in program mpf.cpp:68:2: error: stray '\240' in program mpf.cpp:69:1: error: stray '\302' in program } ^ mpf.cpp:69:1: error: stray '\240' in program mpf.cpp: In function 'int rezolva()': mpf.cpp:62: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:21:17: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result] scanf("%d", &q); ^ mpf.cpp:25:29: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result] scanf("%d %d", &x, &y); ^
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ă.