Detalii evaluare #53715109

Rezumat problemă

#3550 liceu

Marciuc este un băiat foarte neastâmpărat. El refuză să învețe informatică, așa că înainte de fiecare oră el pleacă pentru a explora noul său liceu. La plecare le promite colegilor lui că o să treacă pe la magazin înainte de a se întoarce în clasă, pentru a avea ce să mănânce în pauza următoare. Însă, dacă va ajunge în clasă în mai mult de T secunde, va întarza la ora așa că în acest caz va folosi o ruta directă spre clasă.

Liceul poate fi reprezentat sub forma unei matrice cu n linii și n coloane. Există 3 tipuri de celule:

  • celulă liberă, pe unde băiatul poate avansa, o mutare durând o secundă;
  • celulă ocupată de un zid, pe unde băiatul nu poate avansa;
  • celulă în care se află o scurtătură, ce îl duce într-o secundă de la poziția, x1 y1, la poziția x2 y2 sau invers;

Fiind dat numărul n de linii și de coloane, coordonatele celulelor ocupate de zid și coordonatele scurtăturilor, se cere să se afișeze numărul de secunde în care Marciuc reușește să ajungă în clasă, trecând și pe la magazin. Dacă magazinul nu este accesibil sau daca va ajunge în clasă in mai mult de T secunde, atunci el nu va mai merge la magazin și se va afișa numărul de secunde în care acesta ajunge de la poziția lui la clasă. De asemenea, se va afișa și traseul folosit.

Detalii

Problema liceu Operații I/O liceu.in/liceu.out
Limita timp 0.1 secunde Limita memorie Total: 64 MB / Stivă 8 MB
Id soluție #53715109 Utilizator Stangaciu Teodora (teodora_st)
Fișier liceu.cpp Dimensiune 3.42 KB
Data încărcării 09 Noiembrie 2024, 13:31 Scor / rezultat Eroare de compilare

Evaluare


Mesaj compilare

liceu.cpp: In function 'int main()':
liceu.cpp:50:31: error: cannot convert 'matrice (*)[405]' to 'int (*)[405]' for argument '3' to 'void Traseu(int, int, int (*)[405])'
         Traseu(xmag, ymag, mt1);

                               ^
liceu.cpp:51:25: error: cannot convert 'matrice (*)[405]' to 'int (*)[405]' for argument '3' to 'void Traseu(int, int, int (*)[405])'
         Traseu(n, n, mt2);

                         ^
liceu.cpp:61:25: error: cannot convert 'matrice (*)[405]' to 'int (*)[405]' for argument '3' to 'void Traseu(int, int, int (*)[405])'
         Traseu(n, n, mt1);

                         ^
liceu.cpp: In function 'void Traseu(int, int, int (*)[405])':
liceu.cpp:116:21: error: request for member 'val' in '(*(mt + ((sizetype)(((unsigned int)lin) * 1620u))))[col]', which is of non-class type 'int'
     if(mt[lin][col].val == 1)

                     ^
liceu.cpp:122:29: error: request for member 'val' in '(*(mt + ((sizetype)(((unsigned int)lin) * 1620u))))[col]', which is of non-class type 'int'
             if(mt[lin][col].val == mt[lin+di[k]][col+dj[k]] + 1)

                             ^
liceu.cpp:122:43: error: 'di' was not declared in this scope
             if(mt[lin][col].val == mt[lin+di[k]][col+dj[k]] + 1)

                                           ^
liceu.cpp:122:54: error: 'dj' was not declared in this scope
             if(mt[lin][col].val == mt[lin+di[k]][col+dj[k]] + 1)

                                                      ^
liceu.cpp:124:22: error: 'di' was not declared in this scope
         Traseu(lin + di[p] , col + dj[p]);

                      ^
liceu.cpp:124:36: error: 'dj' was not declared in this scope
         Traseu(lin + di[p] , col + dj[p]);

                                    ^

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