#151
drum
Oraşele Nordemos şi Suderim sunt separate de un munte foarte înalt. Inginerul Negrimon a fost desemnat să construiască un drum prin munte care să unească cele două oraşe. Harta care i s-a pus la dispoziţie descrie muntele ca o matrice cu N
linii şi M
coloane numerotate de la 1
la N
, respectiv de la 1
la M
. Un drum reprezintă o succesiune de elemente din matrice cu proprietatea că oricare două elemente consecutive sunt alăturate, pe linie sau pe coloană. Un drum uneşte oraşul Nordemos (linia 1
) şi oraşul Suderim (linia N
). Valorile din matrice reprezintă densităţile rocilor din munte în acele zone. Pentru fiecare drum posibil se poate calcula valoarea dmax
, egală cu densitatea maximă a rocilor pe care le traversează. Negrimon trebuie să construiască un drum pentru care valoarea dmax
este cea mai mică.
Ajută-l pe Negrimon să afle cea mai mică dintre densităţile dmax
corespunzătoare drumurilor care unesc Nordemos şi Suderim în condiţiile de mai sus.
Urmasii lui Moisil, Iasi, 2013
Problema | drum | Operații I/O |
drum.in /drum.out
|
---|---|---|---|
Limita timp | 0.13 secunde | Limita memorie |
Total: 64 MB
/
Stivă 8 MB
|
Id soluție | #22638624 | Utilizator | |
Fișier | drum.cpp | Dimensiune | 3.00 KB |
Data încărcării | 27 Aprilie 2020, 18:47 | Scor / rezultat | 10 puncte |
drum.cpp: In function 'int main()': drum.cpp:46:19: warning: unused variable 'sum' [-Wunused-variable] long long sum=0; ^ drum.cpp:66:19: warning: unused variable 'sum' [-Wunused-variable] long long sum=0; ^ drum.cpp:29:33: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)', declared with attribute warn_unused_result [-Wunused-result] freopen("drum.in","r",stdin); ^ drum.cpp:30:35: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)', declared with attribute warn_unused_result [-Wunused-result] freopen("drum.out","w",stdout); ^ drum.cpp:31:34: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result] scanf("%d %d %d",&n,&m,&vmax); ^ drum.cpp:34:24: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result] scanf("%d",&nr); ^ drum.cpp:37:28: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result] scanf("%d", &x); ^
Test | Timp | Mesaj evaluare | Scor posibil | Scor obținut | ||
---|---|---|---|---|---|---|
1 | 0 secunde | OK. | 10 | 10 | ||
2 | 0.088 secunde | Caught fatal signal 11 | 10 | 0 | ||
3 | 0.112 secunde | Caught fatal signal 11 | 10 | 0 | ||
4 | 0.568 secunde | Caught fatal signal 11 | 10 | 0 | ||
5 | Depășit | Limita de timp depășită | 10 | 0 | ||
6 | Depășit | Limita de timp depășită | 10 | 0 | ||
7 | Depășit | Limita de timp depășită | 10 | 0 | ||
8 | Depășit | Limita de timp depășită | 10 | 0 | ||
9 | Depășit | Limita de timp depășită | 10 | 0 | ||
10 | Depășit | Limita de timp depășită | 10 | 0 | ||
Punctaj total | 10 |
www.pbinfo.ro permite evaluarea a două tipuri de probleme:
Problema drum face parte din prima categorie. Soluția propusă de tine va fi evaluată astfel:
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ă.