#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 | #51137205 | Utilizator | |
Fișier | zid1.cpp | Dimensiune | 1.81 KB |
Data încărcării | 26 Mai 2024, 16:13 | Scor / rezultat | Eroare de compilare |
zid1.cpp: In function 'int main()': zid1.cpp:42:12: error: no match for 'operator=' (operand types are 'std::vector<std::vector<int> >' and 'std::vector<int>') dp = temp; ^ zid1.cpp:42:12: note: candidates are: In file included from /usr/include/c++/4.8/vector:69:0, from zid1.cpp:3: /usr/include/c++/4.8/bits/vector.tcc:160:5: note: std::vector<_Tp, _Alloc>& std::vector<_Tp, _Alloc>::operator=(const std::vector<_Tp, _Alloc>&) [with _Tp = std::vector<int>; _Alloc = std::allocator<std::vector<int> >] vector<_Tp, _Alloc>:: ^ /usr/include/c++/4.8/bits/vector.tcc:160:5: note: no known conversion for argument 1 from 'std::vector<int>' to 'const std::vector<std::vector<int> >&' In file included from /usr/include/c++/4.8/vector:64:0, from zid1.cpp:3: /usr/include/c++/4.8/bits/stl_vector.h:439:7: note: std::vector<_Tp, _Alloc>& std::vector<_Tp, _Alloc>::operator=(std::vector<_Tp, _Alloc>&&) [with _Tp = std::vector<int>; _Alloc = std::allocator<std::vector<int> >] operator=(vector&& __x) noexcept(_Alloc_traits::_S_nothrow_move()) ^ /usr/include/c++/4.8/bits/stl_vector.h:439:7: note: no known conversion for argument 1 from 'std::vector<int>' to 'std::vector<std::vector<int> >&&' /usr/include/c++/4.8/bits/stl_vector.h:461:7: note: std::vector<_Tp, _Alloc>& std::vector<_Tp, _Alloc>::operator=(std::initializer_list<_Tp>) [with _Tp = std::vector<int>; _Alloc = std::allocator<std::vector<int> >] operator=(initializer_list<value_type> __l) ^ /usr/include/c++/4.8/bits/stl_vector.h:461:7: note: no known conversion for argument 1 from 'std::vector<int>' to 'std::initializer_list<std::vector<int> >' zid1.cpp:46:20: error: cannot bind 'std::basic_ostream<char>' lvalue to 'std::basic_ostream<char>&&' outfile << dp[K] << endl; ^ In file included from /usr/include/c++/4.8/iostream:39:0, from zid1.cpp:1: /usr/include/c++/4.8/ostream:602:5: error: initializing argument 1 of 'std::basic_ostream<_CharT, _Traits>& std::operator<<(std::basic_ostream<_CharT, _Traits>&&, const _Tp&) [with _CharT = char; _Traits = std::char_traits<char>; _Tp = std::vector<int>]' operator<<(basic_ostream<_CharT, _Traits>&& __os, const _Tp& __x) ^
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ă.