Detalii evaluare #58497147

Rezumat problemă

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.

Detalii

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 #58497147 Utilizator Boangiu David (David2013)
Fișier perechi4.cpp Dimensiune 694 B
Data încărcării 11 Iunie 2025, 15:50 Scor / rezultat Eroare de compilare

Evaluare


Mesaj 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;

                            ^
perechi4.cpp: In function 'int main()':
perechi4.cpp:15:18: error: 'y' was not declared in this scope
             fin>>y;

                  ^
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

Cum funcționează evaluarea?

www.pbinfo.ro permite evaluarea a două tipuri de probleme:

  • probleme la care rezolvarea presupune scrierea unui program complet
  • probleme la care rezolvarea presupune scrierea unei secvențe de program - câteva instrucțiuni, o listă de declarații, una sau mai multe funcții, etc.

Problema perechi4 face parte din prima categorie. Soluția propusă de tine va fi evaluată astfel:

  • Programul sursă este compilat folosind compilatorul corespunzător. Dacă în urma compilării se obțin erori sau avertismente, acestea sunt afișate în această pagină.
  • Dacă programul a fost compilat, executabilul obținut va fi rulat, furnizându-i-se unul sau mai multe seturi de date de intrare, în concordanță cu restricțiile specifice problemei. Pentru fiecare set de date se obține un anumit punctaj, în raport cu corectitudinea soluției tale.

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ă.