#1761
Brutar
Renumitul nostru brutar a avut azi noapte un vis tare ciudat: acesta trăia într-un univers paralel în care nu omul îl mănâncă pe blat ci blatul îl mănâncă pe om… (eh, poate nu chiar atât de paralel). Astfel, brutarul nostru a fost atacat de blatul pe care tocmai îl pregătise (pentru prăjituri, evident) și a încercat să scape. Acesta a ieșit din brutărie și a ajuns în fața unui câmp de formă dreptunghiulară, cu dimensiunile cunoscute, ce poate fi împărțit în celule elementare cu latura de o unitate (exact ca o matrice!). Acesta poate intra pe câmp prin orice celulă a primei linii și trebuie să ajungă în orice celulă a ultimei linii (blatul se va întări până va ajunge acolo). Unele celule îi sunt inaccesibile din cauza diverselor obstacole (pietre, pomi, gropi,etc.)
Brutarul nostru se poate deplasa în 6
moduri:
Nord
, Vest
, Sud
, Est
)Mutările speciale vor fi citite din fișier și o mutare se va codifica astfel: xA yB
, unde x
și y
sunt numere naturale nenule iar A
și B
sunt două caractere ce codifică direcția (A
poate fi 'N'
sau 'S'
de la Nord
respectiv Sud
iar B
poate fi ‘E’
sau ‘V’
de la Est
respectiv Vest
)
O mutare specială se poate face dacă celula destinație nu este ocupată de un obstacol și dacă nu implică ieșirea brutarului din matrice.
Brutarul vă roagă să îi specificați un traseu cu număr minim de celule parcurse, ce pornește de pe prima linie și se termină pe ultima linie, pentru a nu fi blătuit (mâncat de blat).
Concursul EMPOWERSOFT, 2016
Problema | Brutar | Operații I/O |
brutar.in /brutar.out
|
---|---|---|---|
Limita timp | 0.1 secunde | Limita memorie |
Total: 16 MB
/
Stivă 4 MB
|
Id soluție | #48894356 | Utilizator | |
Fișier | brutar.cpp | Dimensiune | 3.85 KB |
Data încărcării | 08 Februarie 2024, 15:48 | Scor / rezultat | Eroare de compilare |
brutar.cpp: In function 'std::pair<long long int, std::deque<std::pair<long long int, long long int> > > lee(long long int, long long int)': brutar.cpp:52:20: error: expected unqualified-id before '[' token const auto [i, j] = dq.front(); dq.pop_front(); ^ brutar.cpp:61:30: error: 'i' was not declared in this scope const int newI = i + di[d]; ^ brutar.cpp:62:30: error: 'j' was not declared in this scope const int newJ = j + dj[d]; ^ brutar.cpp:88:20: error: expected unqualified-id before '[' token const auto [i, j] = dq.back(); ^ brutar.cpp:89:13: error: 'i' was not declared in this scope if (i == 1) break; ^ brutar.cpp:91:30: error: 'i' was not declared in this scope const int newI = i - di[d]; ^ brutar.cpp:92:30: error: 'j' was not declared in this scope const int newJ = j - dj[d]; ^
www.pbinfo.ro permite evaluarea a două tipuri de probleme:
Problema Brutar 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ă.