Detalii evaluare #50400677

Rezumat problemă

Un showroom din Strasbourg comercializează o gamă foarte mare de modele de autoturisme, aşezate pe n linii. Pe câte o linie se găsesc numai modele de autoturisme comercializate de acelaşi dealer. Un dealer poate avea modele pe mai multe linii. Parlamentul European doreşte să-şi înnoiască parcul auto şi trimite responsabilul cu activitatea de transport la showroom pentru a se informa cu privire la variantele pe care le are pentru rezolvarea acestei probleme de achiziţie. Responsabilul trebuie să aleagă de la primul dealer \(f_1\) modele, de la al doilea dealer \(f_2\) modele, etc. Şirul de numere \(f_1, f_2, f_3, …\) reprezintă termenii modulo k ai unei progresii aritmetice cu primul termen a şi raţia r. Să se scrie un program care determină: a) Numărul de dealeri prezenţi în showroom; b) Numărul de modalităţi de achiziţie al modelelor de către Parlamentul European, modulo 9001.

ONI 2013, Clasa a X-a

Detalii

Problema ShowRoom Operații I/O showroom.in/showroom.out
Limita timp 0.8 secunde Limita memorie Total: 32 MB / Stivă 16 MB
Id soluție #50400677 Utilizator Candidatu Luca (dragoncrack)
Fișier showroom.cpp Dimensiune 5.02 KB
Data încărcării 08 Aprilie 2024, 12:19 Scor / rezultat 40 puncte

Evaluare


Mesaj compilare

showroom.cpp: In function 'void read()':
showroom.cpp:86:38: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
         for(int j = 0; j < line.size(); j++)

                                      ^
showroom.cpp:88:53: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
             if(line[j] == ' ' || j + 1 == line.size())

                                                     ^
showroom.cpp:90:39: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
                 if(j + 1 == line.size()) masini[i][masini[i].size() - 1].push_back(line[j]);

                                       ^
showroom.cpp: In function 'void make_dealers()':
showroom.cpp:143:43: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
         for(int j = 0; j < masini[i].size(); j++)

                                           ^
showroom.cpp:147:48: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
             for(int k = 0; k < it->second.size(); k++)

                                                ^
showroom.cpp: In function 'int main()':
showroom.cpp:176:43: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
         for(int j = 0; j < dealer[i].size(); j++)

                                           ^
showroom.cpp:178:58: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
             for(int k = 0; k < masini[dealer[i][j]].size(); k++)

                                                          ^
showroom.cpp:174:13: warning: unused variable 'cnt' [-Wunused-variable]
         int cnt = 0;

             ^

Rezultat evaluare

Test Timp Mesaj evaluare Scor posibil Scor obținut
1 0 secunde OK. 10 10
2 0 secunde OK. 10 10
3 0 secunde Raspuns gresit. 10 0
4 0 secunde Raspuns gresit. 10 0
5 0.016 secunde Raspuns gresit. 10 0
6 0.032 secunde Raspuns gresit. 10 0
7 0.056 secunde Raspuns gresit. 10 0
8 0.112 secunde Raspuns gresit. 10 0
9 0.028 secunde OK. 10 10
10 0.108 secunde OK. 10 10
Punctaj total 40

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