#4663
zid1
Fascinată de cultura chineză și Marele Zid Chinezesc, Andra s-a hotărât să își construiască propriul zid în miniatură, de înălțime N
și lățime M
, din piese roșii și galbene pe care le deține. Ea are la dispoziție un număr nelimitat de piese cu lățimea de o unitate și toate înălțimile posibile. Piesele roșii (hóng) au înălțimea impară (1, 3, 5, ...
), pe când piesele galbene (huáng) au înălțimea pară (2, 4, 6, ...
). Piesele nu pot fi rotite și pot fi plasate doar pe verticală. Deoarece culoarea galbenă este considerată cea mai prestigioasă în cultura chineză, Andra vrea ca suma lungimilor tuturor pieselor galbene ce alcătuiesc zidul să fie egală cu un număr K
, special ales astfel încât să aducă noroc. Mai mult de atât, ea se întreabă în câte moduri poate construi zidul astfel încât această condiție să fie respectată. Date fiind N
, M
și K
, determinați numărul de moduri de a construi zidul în condițiile date.
ONI 2024, clasele 11-12
Problema | zid1 | Operații I/O |
zid.in /zid.out
|
---|---|---|---|
Limita timp | 1 secunde | Limita memorie |
Total: 128 MB
/
Stivă 8 MB
|
Id soluție | #51509942 | Utilizator | |
Fișier | zid1.cpp | Dimensiune | 2.47 KB |
Data încărcării | 01 Iulie 2024, 19:49 | Scor / rezultat | Eroare de compilare |
zid1.cpp: In function 'std::vector<int> multiply(const std::vector<int>&, const std::vector<int>&)': zid1.cpp:42:34: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] while (n < a.size() + b.size()) n <<= 1; ^ zid1.cpp:55:43: error: invalid operands of types 'double' and 'const int' to binary 'operator%' result[i] = round(fa[i].real()) % MOD; ^ zid1.cpp: In function 'int solve_zid(int, int, int)': zid1.cpp:80:35: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] if (k < conv_red.size()) { ^ zid1.cpp:83:38: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] if (k < conv_yellow.size()) { ^
www.pbinfo.ro permite evaluarea a două tipuri de probleme:
Problema zid1 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ă.