#2358
castig
Ana şi Bogdan au participat la un concurs şi au obţinut premiul I, respectiv premiul al II-lea. La concurs există n
premii, numerotate de la 1
la n
, în ordinea în care sunt aşezate pe masă. Regulamentul concursului prevede că fiecare câştigător trebuie să aleagă exact k
premii aşezate pe poziţii consecutive. Fiindcă Ana are premiul I, ea poate să îşi aleagă prima premiile. Apoi Bogdan va alege şi el k
premii aşezate pe poziţii consecutive dintre cele rămase după ce a ales Ana. Ana este foarte supărată pe Bogdan, aşa că ea urmăreşte ca Bogdan să câştige cât mai puţin, fără să o intereseze prea mult ce premii alege ea.
Scrieţi un program care, cunoscând n
, k
şi valorile celor n
premii, determină cel mai mic număr valmin
, astfel încât Bogdan să nu poate selecta k
premii aşezate pe poziţii consecutive cu o valoare totală mai mare decât valmin
.
Olimpiada Municipala de Informatica, Iasi, 2018
Problema | castig | Operații I/O |
![]() castig.in /castig.out
|
---|---|---|---|
Limita timp | 0.4 secunde | Limita memorie |
Total: 4 MB
/
Stivă 1 MB
|
Id soluție | #58531531 | Utilizator | |
Fișier | castig.cpp | Dimensiune | 931 B |
Data încărcării | 15 Iunie 2025, 10:42 | Scor / rezultat | Eroare de compilare |
castig.cpp: In function 'int main()': castig.cpp:25:63: error: no matching function for call to 'max(long long int, int)' maxST[i] = max(maxST[i - 1], sum[i] - sum[max(i - k, 0)]); ^ castig.cpp:25:63: note: candidates are: In file included from /usr/include/c++/4.8/bits/char_traits.h:39:0, from /usr/include/c++/4.8/ios:40, from /usr/include/c++/4.8/istream:38, from /usr/include/c++/4.8/fstream:38, from castig.cpp:1: /usr/include/c++/4.8/bits/stl_algobase.h:216:5: note: template<class _Tp> const _Tp& std::max(const _Tp&, const _Tp&) max(const _Tp& __a, const _Tp& __b) ^ /usr/include/c++/4.8/bits/stl_algobase.h:216:5: note: template argument deduction/substitution failed: castig.cpp:25:63: note: deduced conflicting types for parameter 'const _Tp' ('long long int' and 'int') maxST[i] = max(maxST[i - 1], sum[i] - sum[max(i - k, 0)]); ^ In file included from /usr/include/c++/4.8/bits/char_traits.h:39:0, from /usr/include/c++/4.8/ios:40, from /usr/include/c++/4.8/istream:38, from /usr/include/c++/4.8/fstream:38, from castig.cpp:1: /usr/include/c++/4.8/bits/stl_algobase.h:260:5: note: template<class _Tp, class _Compare> const _Tp& std::max(const _Tp&, const _Tp&, _Compare) max(const _Tp& __a, const _Tp& __b, _Compare __comp) ^ /usr/include/c++/4.8/bits/stl_algobase.h:260:5: note: template argument deduction/substitution failed: castig.cpp:25:63: note: deduced conflicting types for parameter 'const _Tp' ('long long int' and 'int') maxST[i] = max(maxST[i - 1], sum[i] - sum[max(i - k, 0)]); ^ In file included from /usr/include/c++/4.8/algorithm:62:0, from castig.cpp:3: /usr/include/c++/4.8/bits/stl_algo.h:4231:5: note: template<class _Tp> _Tp std::max(std::initializer_list<_Tp>) max(initializer_list<_Tp> __l) ^ /usr/include/c++/4.8/bits/stl_algo.h:4231:5: note: template argument deduction/substitution failed: castig.cpp:25:63: note: mismatched types 'std::initializer_list<_Tp>' and 'long long int' maxST[i] = max(maxST[i - 1], sum[i] - sum[max(i - k, 0)]); ^ In file included from /usr/include/c++/4.8/algorithm:62:0, from castig.cpp:3: /usr/include/c++/4.8/bits/stl_algo.h:4236:5: note: template<class _Tp, class _Compare> _Tp std::max(std::initializer_list<_Tp>, _Compare) max(initializer_list<_Tp> __l, _Compare __comp) ^ /usr/include/c++/4.8/bits/stl_algo.h:4236:5: note: template argument deduction/substitution failed: castig.cpp:25:63: note: mismatched types 'std::initializer_list<_Tp>' and 'long long int' maxST[i] = max(maxST[i - 1], sum[i] - sum[max(i - k, 0)]); ^ castig.cpp:35:13: warning: unused variable 'ana' [-Wunused-variable] int ana = sum[i + k - 1] - sum[i - 1]; //[i, i + k - 1] ^
www.pbinfo.ro permite evaluarea a două tipuri de probleme:
Problema castig 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ă.