#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 | #46404716 | Utilizator | |
Fișier | mpf.cpp | Dimensiune | 1018 B |
Data încărcării | 13 Noiembrie 2023, 10:13 | Scor / rezultat | Eroare de compilare |
mpf.cpp: In function 'int main()': mpf.cpp:8:21: error: variable-sized object 'x' may not be initialized bool x[vmax+1]={}; ^ mpf.cpp:21:31: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] for(int i=0 ; i<prms.size() ; i++) ^ mpf.cpp:29:22: error: variable-sized object 'lvl' may not be initialized int lvl[vmax+1]={}; ^ mpf.cpp:43:41: error: 'gcd' was not declared in this scope cnt=lvl[x]+lvl[y]-(2*lvl[gcd(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ă.