Detalii evaluare #55110102

Rezumat problemă

Să ne imaginăm faptul că la un anumit liceu există doar două clase per generație: una de Real și una de Uman. În prezent au loc înscrierile pentru clasa a IX-a. Cele două clase au fiecare câte M locuri disponibile, atât la Real, cât și la Uman. Dacă lista de elevi înscriși la o anumită clasă conține mai mult de M elevi, vor fi admiși acei M elevi care au notele cele mai mari. Ambele clase au deja M elevi înscriși, iar pentru fiecare se știe nota cu care a fost înscris la clasa respectivă.

Mai există însă N elevi, singurii încă neînscriși, care sunt privilegiați în acest proces (fiindcă au terminat gimnaziul la acest liceu). Privilegiul lor constă în următorul fapt: ei se pot înscrie acum, după ce înscrierile publice au fost încheiate, și se cunosc notele de înscriere la ambele clase. Fiecare din cei N elevi are câte două note: nota cu care ar fi înscris la Real și nota cu care ar fi înscris la Uman (acestea pot fi diferite, deoarece examenele de admitere de la cele două clase diferă). Fiecare din cei N elevi va alege să se înscrie în maxim o clasă. Ei își vor coordona alegerile astfel încât să maximizeze numărul de elevi admiși. Deoarece calculele devin destul de complicate, aceștia s-ar putea folosi de ajutorul vostru. Ei doresc răspunsul la două întrebări.

(1) Care este numărul maxim de elevi privilegiaţi care pot fi admiși dacă se pune restricția suplimentară ca toți elevii privilegiați admiși să fie admiși la aceeași clasă?
(2) Care este numărul maxim de elevi privilegiaţi care pot fi admiși dacă aceștia se pot înscrie la clase diferite?

Detalii

Problema admitere Operații I/O admitere.in/admitere.out
Limita timp 1.5 secunde Limita memorie Total: 32 MB / Stivă 8 MB
Id soluție #55110102 Utilizator Patpaiac Alexandru (AlexPat)
Fișier admitere.cpp Dimensiune 5.67 KB
Data încărcării 25 Decembrie 2024, 01:19 Scor / rezultat Eroare de compilare

Evaluare


Mesaj compilare

admitere.cpp: In function 'int cautbin(int, int)':
admitere.cpp:27:25: error: reference to 'real' is ambiguous
         if (poz+pas<=n&&real[poz+pas].r<=target)

                         ^
admitere.cpp:8:16: note: candidates are: student real [2005]
 } elevi[2005], real[2005], uman[2005];

                ^
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 admitere.cpp:1:
/usr/include/c++/4.8/complex:1850:5: note:                 template<class _Tp> typename __gnu_cxx::__promote<_Tp>::__type std::real(_Tp)
     real(_Tp __x)
     ^
/usr/include/c++/4.8/complex:538:5: note:                 template<class _Tp> constexpr _Tp std::real(const std::complex<_Tp>&)
     real(const complex<_Tp>& __z)
     ^
admitere.cpp: In function 'int main()':
admitere.cpp:73:13: error: reference to 'real' is ambiguous
             real[i]=elevi[i];

             ^
admitere.cpp:8:16: note: candidates are: student real [2005]
 } elevi[2005], real[2005], uman[2005];

                ^
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 admitere.cpp:1:
/usr/include/c++/4.8/complex:1850:5: note:                 template<class _Tp> typename __gnu_cxx::__promote<_Tp>::__type std::real(_Tp)
     real(_Tp __x)
     ^
/usr/include/c++/4.8/complex:538:5: note:                 template<class _Tp> constexpr _Tp std::real(const std::complex<_Tp>&)
     real(const complex<_Tp>& __z)
     ^
admitere.cpp:76:14: error: reference to 'real' is ambiguous
         sort(real+1, real+n+1, cmpr);

              ^
admitere.cpp:8:16: note: candidates are: student real [2005]
 } elevi[2005], real[2005], uman[2005];

                ^
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 admitere.cpp:1:
/usr/include/c++/4.8/complex:1850:5: note:                 template<class _Tp> typename __gnu_cxx::__promote<_Tp>::__type std::real(_Tp)
     real(_Tp __x)
     ^
/usr/include/c++/4.8/complex:538:5: note:                 template<class _Tp> constexpr _Tp std::real(const std::complex<_Tp>&)
     real(const complex<_Tp>& __z)
     ^
admitere.cpp:76:22: error: reference to 'real' is ambiguous
         sort(real+1, real+n+1, cmpr);

                      ^
admitere.cpp:8:16: note: candidates are: student real [2005]
 } elevi[2005], real[2005], uman[2005];

                ^
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 admitere.cpp:1:
/usr/include/c++/4.8/complex:1850:5: note:                 template<class _Tp> typename __gnu_cxx::__promote<_Tp>::__type std::real(_Tp)
     real(_Tp __x)
     ^
/usr/include/c++/4.8/complex:538:5: note:                 template<class _Tp> constexpr _Tp std::real(const std::complex<_Tp>&)
     real(const complex<_Tp>& __z)
     ^
admitere.cpp:95:29: error: reference to 'real' is ambiguous
                         ans[real[j].ind]='R';

                             ^
admitere.cpp:8:16: note: candidates are: student real [2005]
 } elevi[2005], real[2005], uman[2005];

                ^
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 admitere.cpp:1:
/usr/include/c++/4.8/complex:1850:5: note:                 template<class _Tp> typename __gnu_cxx::__promote<_Tp>::__type std::real(_Tp)
     real(_Tp __x)
     ^
/usr/include/c++/4.8/complex:538:5: note:                 template<class _Tp> constexpr _Tp std::real(const std::complex<_Tp>&)
     real(const complex<_Tp>& __z)
     ^
admitere.cpp:99:29: error: reference to 'real' is ambiguous
                         ans[real[j].ind]='X';

                             ^
admitere.cpp:8:16: note: candidates are: student real [2005]
 } elevi[2005], real[2005], uman[2005];

                ^
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 admitere.cpp:1:
/usr/include/c++/4.8/complex:1850:5: note:                 template<class _Tp> typename __gnu_cxx::__promote<_Tp>::__type std::real(_Tp)
     real(_Tp __x)
     ^
/usr/include/c++/4.8/complex:538:5: note:                 template<class _Tp> constexpr _Tp std::real(const std::complex<_Tp>&)
     real(const complex<_Tp>& __z)
     ^
admitere.cpp:158:13: error: reference to 'real' is ambiguous
             real[i]=elevi[i];

             ^
admitere.cpp:8:16: note: candidates are: student real [2005]
 } elevi[2005], real[2005], uman[2005];

                ^
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 admitere.cpp:1:
/usr/include/c++/4.8/complex:1850:5: note:                 template<class _Tp> typename __gnu_cxx::__promote<_Tp>::__type std::real(_Tp)
     real(_Tp __x)
     ^
/usr/include/c++/4.8/complex:538:5: note:                 template<class _Tp> constexpr _Tp std::real(const std::complex<_Tp>&)
     real(const complex<_Tp>& __z)
     ^
admitere.cpp:161:14: error: reference to 'real' is ambiguous
         sort(real+1, real+n+1, cmpr);

              ^
admitere.cpp:8:16: note: candidates are: student real [2005]
 } elevi[2005], real[2005], uman[2005];

                ^
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 admitere.cpp:1:
/usr/include/c++/4.8/complex:1850:5: note:                 template<class _Tp> typename __gnu_cxx::__promote<_Tp>::__type std::real(_Tp)
     real(_Tp __x)
     ^
/usr/include/c++/4.8/complex:538:5: note:                 template<class _Tp> constexpr _Tp std::real(const std::complex<_Tp>&)
     real(const complex<_Tp>& __z)
     ^
admitere.cpp:161:22: error: reference to 'real' is ambiguous
         sort(real+1, real+n+1, cmpr);

                      ^
admitere.cpp:8:16: note: candidates are: student real [2005]
 } elevi[2005], real[2005], uman[2005];

                ^
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 admitere.cpp:1:
/usr/include/c++/4.8/complex:1850:5: note:                 template<class _Tp> typename __gnu_cxx::__promote<_Tp>::__type std::real(_Tp)
     real(_Tp __x)
     ^
/usr/include/c++/4.8/complex:538:5: note:                 template<class _Tp> constexpr _Tp std::real(const std::complex<_Tp>&)
     real(const complex<_Tp>& __z)
     ^
admitere.cpp:183:31: error: reference to 'real' is ambiguous
                     construct[real[j].ind]='R'; ///adaugat cazul cand nu functioneaza.

                               ^
admitere.cpp:8:16: note: candidates are: student real [2005]
 } elevi[2005], real[2005], uman[2005];

                ^
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 admitere.cpp:1:
/usr/include/c++/4.8/complex:1850:5: note:                 template<class _Tp> typename __gnu_cxx::__promote<_Tp>::__type std::real(_Tp)
     real(_Tp __x)
     ^
/usr/include/c++/4.8/complex:538:5: note:                 template<class _Tp> constexpr _Tp std::real(const std::complex<_Tp>&)
     real(const complex<_Tp>& __z)
     ^
admitere.cpp:185:21: warning: unused variable 'invalid' [-Wunused-variable]
                 int invalid=0;

                     ^

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