Detalii evaluare #55152422

Rezumat problemă

#1998 Rover

NASA plănuiește o nouă misiune Rover pe Marte în anul 2020. Principalul obiectiv al acestei misiuni este de a determina, cu ajutorul unui nou Rover, dacă a existat în trecut viață pe Marte. Până când va fi lansată misiunea, Roverul este supus la tot felul de teste în laboratoarele NASA. Într-unul din teste, Roverul trebuie să parcurgă o suprafață de forma unui caroiaj cu N linii și N coloane. Acesta pornește din zona de coordonate (1,1) și trebuie să ajungă în zona de coordonate (N,N), la fiecare pas putându-se deplasa din zona în care se află într-una din zonele învecinate la nord, sud, est sau vest. Pentru fiecare zonă de coordonate (i,j) se cunoaște A[i,j], stabilitatea terenului din acea zonă. Știind că Roverul are o greutate G, o zonă cu stabilitatea terenului cel puțin egală cu G se consideră o zonă sigură pentru deplasarea Roverului, iar o zonă cu stabilitatea terenului mai mică decât G se consideră o zonă periculoasă pentru Rover.

1. Determinați numărul minim posibil de zone periculoase pe care le traversează Roverul pentru a ajunge din zona (1,1) în zona (N,N).
2. Determinați greutatea maximă pe care o poate avea un Rover care să ajungă din zona (1,1) în zona (N,N), fără a traversa nicio zonă periculoasă pentru el.

Detalii

Problema Rover Operații I/O rover.in/rover.out
Limita timp 0.5 secunde Limita memorie Total: 64 MB / Stivă 32 MB
Id soluție #55152422 Utilizator Pahonie George (Hezov)
Fișier rover.cpp Dimensiune 1.66 KB
Data încărcării 31 Decembrie 2024, 14:19 Scor / rezultat 100 puncte

Evaluare


Mesaj compilare

rover.cpp: In function 'int solve(int)':
rover.cpp:36:65: warning: narrowing conversion of 'cx' from 'int' to 'short int' inside { } [-Wnarrowing]
                 dist[cx][cy] = dist[x][y], dq.push_front({cx,cy});

                                                                 ^
rover.cpp:36:65: warning: narrowing conversion of 'cy' from 'int' to 'short int' inside { } [-Wnarrowing]
rover.cpp:37:67: warning: narrowing conversion of 'cx' from 'int' to 'short int' inside { } [-Wnarrowing]
             else dist[cx][cy] = dist[x][y]+1, dq.push_back({cx,cy});

                                                                   ^
rover.cpp:37:67: warning: narrowing conversion of 'cy' from 'int' to 'short int' inside { } [-Wnarrowing]

Rezultat evaluare

Test Timp Mesaj evaluare Scor posibil Scor obținut
0 0 secunde OK. 10 10
1 0 secunde OK. 5 5
2 0 secunde OK. 5 5
3 0.004 secunde OK. 5 5
4 0.008 secunde OK. 5 5
5 0.02 secunde OK. 5 5
6 0.024 secunde OK. 5 5
7 0.028 secunde OK. 5 5
8 0.028 secunde OK. 5 5
9 0 secunde OK. 10 10
10 0 secunde OK. 5 5
11 0.008 secunde OK. 5 5
12 0.028 secunde OK. 5 5
13 0.036 secunde OK. 5 5
14 0.064 secunde OK. 5 5
15 0.056 secunde OK. 5 5
16 0.088 secunde OK. 5 5
17 0.116 secunde OK. 5 5
Punctaj total 100

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