#2236
swap01
Se consideră un șir binar a[1]
, a[2]
, …, a[n]
. Asupra șirului se poate efectua operația swap(i, j)
prin care se interschimbă valorile a[i]
și a[j]
. Să se determine numărul minim de operații swap
care pot fi efectuate astfel încât toate valorile de 1
să apară pe poziții consecutive în șir.
-
Problema | swap01 | Operații I/O | tastatură/ecran |
---|---|---|---|
Limita timp | 0.1 secunde | Limita memorie |
Total: 64 MB
/
Stivă 8 MB
|
Id soluție | #54857199 | Utilizator | |
Fișier | swap01.cpp | Dimensiune | 309 B |
Data încărcării | 10 Decembrie 2024, 14:49 | Scor / rezultat | Eroare de compilare |
swap01.cpp: In function 'int main()': swap01.cpp:14:60: error: no matching function for call to 'max(int&, long long int)' for (int i = t+1; i <= n; i++) ss = max(ss, s[i]-s[i-t]); ^ swap01.cpp:14:60: 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/ostream:38, from /usr/include/c++/4.8/iostream:39, from swap01.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: swap01.cpp:14:60: note: deduced conflicting types for parameter 'const _Tp' ('int' and 'long long int') for (int i = t+1; i <= n; i++) ss = max(ss, s[i]-s[i-t]); ^ 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/ostream:38, from /usr/include/c++/4.8/iostream:39, from swap01.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: swap01.cpp:14:60: note: deduced conflicting types for parameter 'const _Tp' ('int' and 'long long int') for (int i = t+1; i <= n; i++) ss = max(ss, s[i]-s[i-t]); ^
www.pbinfo.ro permite evaluarea a două tipuri de probleme:
Problema swap01 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ă.