Detalii evaluare #34883169

Rezumat problemă

Ionel este mare pasionat al jocului Triburile. Ideea jocului este aceea că fiecare jucător deţine la un moment dat câteva sate dintr-o zonă şi încearcă să domine acea zonă cucerind satele deţinute în respectiva zonă de alţi jucători. Ionel a ajuns să deţină foarte multe sate şi îi este din ce în ce mai greu să-şi organizeze atacurile.

În acest moment el are n sate, numerotate de la 1 la n, şi urmează să organizeze atacuri coordonate asupra satelor duşmane. Ionel cunoaşte cât timp face armata din fiecare sat al său până la fiecare sat inamic.

Ionel a ales două sate inamice X şi Y pe care vrea să le atace. El s-a gândit la următorul scenariu: selectează k sate diferite ale sale şi trimite toate armatele din ele la atac asupra unuia dintre cele două sate inamice. Toate cele k atacuri trebuie să fie coordonate, adică toate trupele provenind din cele k sate trebuie să sosească în satul atacat exact la aceeaşi oră (pentru aceasta, ele pot pleca la momente diferite de timp). Se ştie că în urma acestui atac supravieţuiesc din fiecare sat al lui Ionel suficiente trupe care se întorc în satul de unde provin şi pot participa la un nou atac. Ionel va selecta apoi din nou k sate de-ale sale, printre care pot fi şi sate care au participat la primul atac, şi va lansa ofensiva asupra celuilalt sat inamic. Şi de data aceasta armatele provenind de la cele k sate trebuie sa ajungă în acelaşi timp la obiectivul pe care îl atacă.

Ionel doreşte ca timpul scurs de la plecarea primei armate până la momentul sosirii armatelor în cel de al doilea sat atacat să fie cât mai scurt, pentru a putea surprinde în felul acesta inamicul.

Vom considera că prima armată a lui Ionel va pleca la atac la ora 00:00, şi toate cele 2k atacuri îşi vor atinge ţinta cel târziu la ora 23:59 a aceleiaşi zile.

Timpul necesar revenirii unei armate în satul de origine după atacul asupra unui sat inamic este egal cu timpul necesar deplasării din satul de origine spre respectivul sat atacat, iar atacul este instantaneu (nu consumă timp).

Se cere să se determine ora la care ajung trupele în cel de al doilea sat atacat, conform cerinţelor de mai sus.

Detalii

Problema Triburi Operații I/O triburi.in/triburi.out
Limita timp 0.1 secunde Limita memorie Total: 16 MB / Stivă 8 MB
Id soluție #34883169 Utilizator Timbus Maria (MariaTimbus)
Fișier triburi.cpp Dimensiune 1.23 KB
Data încărcării 16 Februarie 2022, 23:42 Scor / rezultat Eroare de compilare

Evaluare


Mesaj compilare

triburi.cpp:5:13: error: variable 'std::ifstream cin' has initializer but incomplete type
 ifstream cin("triburi.in");

             ^
triburi.cpp:6:14: error: variable 'std::ofstream cout' has initializer but incomplete type
 ofstream cout("triburi.out");

              ^
triburi.cpp: In function 'int calc(int)':
triburi.cpp:43:33: error: expected ')' before ';' token
             timp=max(timp,vvv[i];)

                                 ^
triburi.cpp:43:34: error: expected primary-expression before ')' token
             timp=max(timp,vvv[i];)

                                  ^
triburi.cpp:43:34: error: expected ';' before ')' token
triburi.cpp: At global scope:
triburi.cpp:52:4: error: expected primary-expression before 'int'
    int i,h,m,mini=24*60+1;

    ^
triburi.cpp:52:4: error: expected '}' before 'int'
triburi.cpp:52:4: error: expected ',' or ';' before 'int'
triburi.cpp:53:4: error: reference to 'cin' is ambiguous
    cin>>n>>k;

    ^
triburi.cpp:5:10: note: candidates are: <typeprefixerror>cin
 ifstream cin("triburi.in");

          ^
In file included from triburi.cpp:1:0:
/usr/include/c++/4.8/iostream:60:18: note:                 std::istream std::cin
   extern istream cin;  /// Linked to standard input
                  ^
triburi.cpp:53:4: error: 'cin' does not name a type
    cin>>n>>k;

    ^
triburi.cpp:54:4: error: expected unqualified-id before 'for'
    for(i=1; i<=n; i++)

    ^
triburi.cpp:54:13: error: 'i' does not name a type
    for(i=1; i<=n; i++)

             ^
triburi.cpp:54:19: error: 'i' does not name a type
    for(i=1; i<=n; i++)

                   ^
triburi.cpp:61:4: error: expected unqualified-id before 'for'
    for(int t=0; i<= 24*60 && t<min ; t++)

    ^
triburi.cpp:61:17: error: 'i' does not name a type
    for(int t=0; i<= 24*60 && t<min ; t++)

                 ^
triburi.cpp:61:38: error: 't' does not name a type
    for(int t=0; i<= 24*60 && t<min ; t++)

                                      ^
triburi.cpp:63:4: error: expected unqualified-id before 'for'
    for(i=1; i<=n; i++)

    ^
triburi.cpp:63:13: error: 'i' does not name a type
    for(i=1; i<=n; i++)

             ^
triburi.cpp:63:19: error: 'i' does not name a type
    for(i=1; i<=n; i++)

                   ^
triburi.cpp:65:4: error: expected unqualified-id before 'for'
    for(int t=0; t<=24*60 && t<mini; t++)

    ^
triburi.cpp:65:17: error: 't' does not name a type
    for(int t=0; t<=24*60 && t<mini; t++)

                 ^
triburi.cpp:65:37: error: 't' does not name a type
    for(int t=0; t<=24*60 && t<mini; t++)

                                     ^
triburi.cpp:69:4: error: reference to 'cout' is ambiguous
    cout<<mini/60<<" "<<mini%60;

    ^
triburi.cpp:6:10: note: candidates are: <typeprefixerror>cout
 ofstream cout("triburi.out");

          ^
In file included from triburi.cpp:1:0:
/usr/include/c++/4.8/iostream:61:18: note:                 std::ostream std::cout
   extern ostream cout;  /// Linked to standard output
                  ^
triburi.cpp:69:4: error: 'cout' does not name a type
    cout<<mini/60<<" "<<mini%60;

    ^
triburi.cpp:70:4: error: expected unqualified-id before 'return'
    return 0;

    ^
triburi.cpp:71:1: error: expected declaration before '}' token
 }
 ^

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