#4831
perechi4
Gigel a primit o sarcină interesantă: se dă un șir de N
numere numere naturale și un număr natural K
. Ajutați-l pe Gigel să rezolve următoarele două cerințe.
1) Fie X
primul număr din șir. Determinați poziția celui mai mic număr Y
care aparține șirului, astfel încât suma celor două numere X
și Y
să fie divizibilă cu K
. Dacă valoarea Y
, cu proprietatea precizată, apare de mai multe ori în șir, se ia în considerare poziția cea mai din dreapta. Există cel puțin un astfel de număr Y
, care aparține șirului.
2) Determinați numărul minim de elemente care trebuie eliminate din șir astfel încât elementele rămase să poată fi grupate în perechi disjuncte (fiecare element rămas aparține unei singure perechi), cu proprietatea că suma celor două valori din fiecare pereche este divizibilă cu K
.
ONI 2025, clasa a 5-a
Problema | perechi4 | Operații I/O |
![]() perechi.in /perechi.out
|
---|---|---|---|
Limita timp | 0.1 secunde | Limita memorie |
Total: 64 MB
/
Stivă 8 MB
|
Id soluție | #58497155 | Utilizator | |
Fișier | perechi4.cpp | Dimensiune | 696 B |
Data încărcării | 11 Iunie 2025, 15:50 | Scor / rezultat | Eroare de compilare |
perechi4.cpp:4:28: warning: overflow in implicit constant conversion [-Woverflow] int x,a[100005],k,c,n,i,mn=9999999999,poz,p,fr[100005],r,j,y; ^ perechi4.cpp: In function 'int main()': perechi4.cpp:33:31: error: no matching function for call to 'abs(int&, int&)' r+=abs(fr[i],fr[j]); ^ perechi4.cpp:33:31: note: candidates are: In file included from /usr/include/c++/4.8/cstdlib:72:0, from /usr/include/i386-linux-gnu/c++/4.8/bits/stdc++.h:47, from perechi4.cpp:1: /usr/include/stdlib.h:775:12: note: int abs(int) extern int abs (int __x) __THROW __attribute__ ((__const__)) __wur; ^ /usr/include/stdlib.h:775:12: note: candidate expects 1 argument, 2 provided In file included from /usr/include/c++/4.8/valarray:587:0, from /usr/include/i386-linux-gnu/c++/4.8/bits/stdc++.h:94, from perechi4.cpp:1: /usr/include/c++/4.8/bits/valarray_after.h:442:5: note: template<class _Tp> std::_Expr<std::_UnClos<std::_Abs, std::_ValArray, _Tp>, _Tp> std::abs(const std::valarray<_Tp>&) _DEFINE_EXPR_UNARY_FUNCTION(abs, _Abs) ^ /usr/include/c++/4.8/bits/valarray_after.h:442:5: note: template argument deduction/substitution failed: perechi4.cpp:33:31: note: mismatched types 'const std::valarray<_Tp>' and 'int' r+=abs(fr[i],fr[j]); ^ In file included from /usr/include/c++/4.8/valarray:587:0, from /usr/include/i386-linux-gnu/c++/4.8/bits/stdc++.h:94, from perechi4.cpp:1: /usr/include/c++/4.8/bits/valarray_after.h:442:5: note: template<class _Dom> std::_Expr<std::_UnClos<std::_Abs, std::_Expr, _Dom>, typename _Dom::value_type> std::abs(const std::_Expr<_Dom1, typename _Dom1::value_type>&) _DEFINE_EXPR_UNARY_FUNCTION(abs, _Abs) ^ /usr/include/c++/4.8/bits/valarray_after.h:442:5: note: template argument deduction/substitution failed: perechi4.cpp:33:31: note: mismatched types 'const std::_Expr<_Dom1, typename _Dom1::value_type>' and 'int' r+=abs(fr[i],fr[j]); ^ In file included from /usr/include/c++/4.8/ccomplex:38:0, from /usr/include/i386-linux-gnu/c++/4.8/bits/stdc++.h:52, from perechi4.cpp:1: /usr/include/c++/4.8/complex:595:5: note: template<class _Tp> _Tp std::abs(const std::complex<_Tp>&) abs(const complex<_Tp>& __z) { return __complex_abs(__z.__rep()); } ^ /usr/include/c++/4.8/complex:595:5: note: template argument deduction/substitution failed: perechi4.cpp:33:31: note: mismatched types 'const std::complex<_Tp>' and 'int' r+=abs(fr[i],fr[j]); ^ In file included from /usr/include/i386-linux-gnu/c++/4.8/bits/stdc++.h:47:0, from perechi4.cpp:1: /usr/include/c++/4.8/cstdlib:174:3: note: long long int std::abs(long long int) abs(long long __x) { return __builtin_llabs (__x); } ^ /usr/include/c++/4.8/cstdlib:174:3: note: candidate expects 1 argument, 2 provided /usr/include/c++/4.8/cstdlib:166:3: note: long int std::abs(long int) abs(long __i) { return __builtin_labs(__i); } ^ /usr/include/c++/4.8/cstdlib:166:3: note: candidate expects 1 argument, 2 provided In file included from /usr/include/i386-linux-gnu/c++/4.8/bits/stdc++.h:41:0, from perechi4.cpp:1: /usr/include/c++/4.8/cmath:99:5: note: template<class _Tp> constexpr typename __gnu_cxx::__enable_if<std::__is_integer<_Tp>::__value, double>::__type std::abs(_Tp) abs(_Tp __x) ^ /usr/include/c++/4.8/cmath:99:5: note: template argument deduction/substitution failed: perechi4.cpp:33:31: note: candidate expects 1 argument, 2 provided r+=abs(fr[i],fr[j]); ^ In file included from /usr/include/i386-linux-gnu/c++/4.8/bits/stdc++.h:41:0, from perechi4.cpp:1: /usr/include/c++/4.8/cmath:91:3: note: constexpr long double std::abs(long double) abs(long double __x) ^ /usr/include/c++/4.8/cmath:91:3: note: candidate expects 1 argument, 2 provided /usr/include/c++/4.8/cmath:87:3: note: constexpr float std::abs(float) abs(float __x) ^ /usr/include/c++/4.8/cmath:87:3: note: candidate expects 1 argument, 2 provided /usr/include/c++/4.8/cmath:81:3: note: constexpr double std::abs(double) abs(double __x) ^ /usr/include/c++/4.8/cmath:81:3: note: candidate expects 1 argument, 2 provided
www.pbinfo.ro permite evaluarea a două tipuri de probleme:
Problema perechi4 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ă.