#1207
Cifre9
Maia tocmai a învăţat la şcoală să facă adunări cu numere naturale având mai multe cifre. Pentru că îi place foarte mult matematica s-a apucat să scrie pe o foaie multe numere naturale, cu una sau mai multe cifre, şi a început să le adune.
După o vreme s-a cam plictisit şi s-a gândit să afle cea mai mare sumă ce s-ar putea obţine dacă s-ar schimba între ele cifrele numerelor de pe foaie. Are însă o singură dorinţă: după ce schimbă cifrele între ele să rămână acelaşi număr de numere cu o cifră, acelaşi număr de numere cu două cifre şi aşa mai departe.
Cerinţe
Scrieţi un program care să determine
a) suma maximă ce se poate obţine schimbând între ele cifrele numerelor iniţiale;
b) un şir de numere pentru care se obţine suma maximă, respectând restricţiile din enunţ.
ONI GIM 2014, Clasa a VIII-a
Problema | Cifre9 | Operații I/O |
cifre9.in /cifre9.out
|
---|---|---|---|
Limita timp | 0.5 secunde | Limita memorie |
Total: 16 MB
/
Stivă 1 MB
|
Id soluție | #55126127 | Utilizator | |
Fișier | cifre9.cpp | Dimensiune | 1.87 KB |
Data încărcării | 27 Decembrie 2024, 22:56 | Scor / rezultat | Eroare de compilare |
cifre9.cpp: In function 'int main()': cifre9.cpp:27:55: error: no matching function for call to 'std::vector<int>::push_back(std::vector<int>&)' digitsByLength[number.size()].push_back(digits); ^ cifre9.cpp:27:55: note: candidates are: In file included from /usr/include/c++/4.8/vector:64:0, from cifre9.cpp:2: /usr/include/c++/4.8/bits/stl_vector.h:901:7: note: void std::vector<_Tp, _Alloc>::push_back(const value_type&) [with _Tp = int; _Alloc = std::allocator<int>; std::vector<_Tp, _Alloc>::value_type = int] push_back(const value_type& __x) ^ /usr/include/c++/4.8/bits/stl_vector.h:901:7: note: no known conversion for argument 1 from 'std::vector<int>' to 'const value_type& {aka const int&}' /usr/include/c++/4.8/bits/stl_vector.h:919:7: note: void std::vector<_Tp, _Alloc>::push_back(std::vector<_Tp, _Alloc>::value_type&&) [with _Tp = int; _Alloc = std::allocator<int>; std::vector<_Tp, _Alloc>::value_type = int] push_back(value_type&& __x) ^ /usr/include/c++/4.8/bits/stl_vector.h:919:7: note: no known conversion for argument 1 from 'std::vector<int>' to 'std::vector<int>::value_type&& {aka int&&}' cifre9.cpp:34:54: error: request for member 'begin' in 'digits', which is of non-class type 'int' allDigits.insert(allDigits.end(), digits.begin(), digits.end()); ^ cifre9.cpp:34:70: error: request for member 'end' in 'digits', which is of non-class type 'int' allDigits.insert(allDigits.end(), digits.begin(), digits.end()); ^ cifre9.cpp:47:20: warning: unused variable 'digits' [-Wunused-variable] for (auto &digits : digitsByLength[length]) { ^
www.pbinfo.ro permite evaluarea a două tipuri de probleme:
Problema Cifre9 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ă.