#4610
poseidon
În Tărâmul Magic al Insulelor, se desfășoară o vânătoare anuală de comori, unde echipele explorează insule fermecate, delimitate de apa ce le înconjoară. La ordinul regelui A., sunt ascunse comori pe fiecare insulă. Harta tărâmului este reprezentată sub forma unei matrice de dimensiune 𝑛 × 𝑚
, ale cărei elemente codifică zone pătratice, cu latura de 1 metru. Acestea pot fi:
−1
;0
; sauDouă zone se consideră vecine dacă au o latură comună. Două zone aparţin aceleiaşi insule dacă ele sunt vecine sau dacă se poate ajunge de la o zonă la cealaltă pe un drum care parcurge o succesiune de zone, oricare două zone parcurse consecutiv fiind vecine. În acest an, căpitanul Poseidon dorește să facă o farsă regelui A., permutând comorile, astfel încât fiecare comoară să fie mutată într-o zona în care inițial a fost o altă comoară. Totuși, pentru a nu atrage atenția prea mult, comorile vor rămâne în cadrul insulei pe care se aflau inițial
Pentru început, căpitanul Poseidon își propune să rezolve următoarele cerințe:
1 000 000 007
.Problema | poseidon | Operații I/O |
poseidon.in /poseidon.out
|
---|---|---|---|
Limita timp | 0.1 secunde | Limita memorie |
Total: 64 MB
/
Stivă 8 MB
|
Id soluție | #51793859 | Utilizator | |
Fișier | poseidon.cpp | Dimensiune | 3.76 KB |
Data încărcării | 20 August 2024, 20:32 | Scor / rezultat | 30 puncte |
poseidon.cpp: In function 'void Lee(short int, short int)': poseidon.cpp:50:66: warning: narrowing conversion of '(((int)Lista.std::queue<_Tp, _Sequence>::front<Lee(short int, short int)::Coords, std::deque<Lee(short int, short int)::Coords, std::allocator<Lee(short int, short int)::Coords> > >().Lee(short int, short int)::Coords::Y) + -1)' from 'int' to 'short int' inside { } [-Wnarrowing] Lista.push({Lista.front().X, Lista.front().Y - 1}); ^ poseidon.cpp:55:49: warning: narrowing conversion of '(((int)Lista.std::queue<_Tp, _Sequence>::front<Lee(short int, short int)::Coords, std::deque<Lee(short int, short int)::Coords, std::allocator<Lee(short int, short int)::Coords> > >().Lee(short int, short int)::Coords::X) + -1)' from 'int' to 'short int' inside { } [-Wnarrowing] Lista.push({Lista.front().X - 1, Lista.front().Y}); ^ poseidon.cpp:60:49: warning: narrowing conversion of '(((int)Lista.std::queue<_Tp, _Sequence>::front<Lee(short int, short int)::Coords, std::deque<Lee(short int, short int)::Coords, std::allocator<Lee(short int, short int)::Coords> > >().Lee(short int, short int)::Coords::X) + 1)' from 'int' to 'short int' inside { } [-Wnarrowing] Lista.push({Lista.front().X + 1, Lista.front().Y}); ^ poseidon.cpp:65:66: warning: narrowing conversion of '(((int)Lista.std::queue<_Tp, _Sequence>::front<Lee(short int, short int)::Coords, std::deque<Lee(short int, short int)::Coords, std::allocator<Lee(short int, short int)::Coords> > >().Lee(short int, short int)::Coords::Y) + 1)' from 'int' to 'short int' inside { } [-Wnarrowing] Lista.push({Lista.front().X, Lista.front().Y + 1}); ^ poseidon.cpp: In function 'int main()': poseidon.cpp:110:36: warning: comparison between signed and unsigned integer expressions [-Wsign-compare] for (int i=0;i<insule.size();i++){ ^
Test | Timp | Mesaj evaluare | Scor posibil | Scor obținut | ||
---|---|---|---|---|---|---|
0 | 0.008 secunde | Caught fatal signal 11 | 5 | 0 | ||
1 | 0 secunde | OK. | 5 | 5 | ||
2 | 0.008 secunde | Caught fatal signal 11 | 5 | 0 | ||
3 | 0.008 secunde | Caught fatal signal 11 | 5 | 0 | ||
4 | 0.012 secunde | Caught fatal signal 11 | 5 | 0 | ||
5 | 0 secunde | OK. | 5 | 5 | ||
6 | 0 secunde | OK. | 5 | 5 | ||
7 | 0.004 secunde | OK. | 5 | 5 | ||
8 | 0.076 secunde | Raspuns gresit. | 5 | 0 | ||
9 | 0 secunde | OK. | 5 | 5 | ||
10 | 0 secunde | Raspuns gresit. | 5 | 0 | ||
11 | 0 secunde | Raspuns gresit. | 5 | 0 | ||
12 | 0 secunde | OK. | 5 | 5 | ||
13 | 0.004 secunde | Raspuns gresit. | 5 | 0 | ||
14 | 0 secunde | Raspuns gresit. | 5 | 0 | ||
15 | 0.008 secunde | Caught fatal signal 11 | 5 | 0 | ||
16 | 0.076 secunde | Raspuns gresit. | 5 | 0 | ||
17 | 0.036 secunde | Raspuns gresit. | 5 | 0 | ||
18 | 0.048 secunde | Raspuns gresit. | 5 | 0 | ||
19 | 0.032 secunde | Raspuns gresit. | 5 | 0 | ||
Punctaj total | 30 |
www.pbinfo.ro permite evaluarea a două tipuri de probleme:
Problema poseidon 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ă.