Pe un teren de formă pătrată sunt zone de uscat şi lacuri. Harta terenului este memorată într-un tablou bidimensional cu valori (apă) sau (uscat). Liniile sunt numerotate de la la de sus în jos şi coloanele de la la , de la stânga la dreapta.
Fiecare lac este înconjurat de o suprafaţă de teren uscat. Excepţie fac doar lacurile situate la marginea terenului care sunt înconjurate de uscat doar prin interiorul terenului nu şi prin afara acestuia.
Cerință
Se doreşte să se traverseze terenul pe uscat, de la poziţia la poziţia , pe un drum de lungime minimă, mergând pas cu pas.
La un pas, se ajunge de la un pătrăţel la altul învecinat cu el spre nord, est, sud sau vest. Să se scrie un program care:
a) Determină numărul lacurilor care sunt de formă pătrată şi în acelaşi timp sunt „pline de ”
b) În cazul în care toate lacurile sunt de formă pătrată şi în acelaşi timp „pline de ”, determinaţi un drum cu proprietatea de mai sus.
Date de intrare
Fişierul de intrare lacuri.in
are pe prima linie numărul , iar pe următoarele linii este harta terenului (fiecare linie are valori sau , separate de câte un spaţiu).
Date de ieșire
Fişierul de ieşire lacuri.out
va conţine:
- pe prima linie: numărul de lacuri ce sunt de formă pătrată şi în acelaşi timp „pline de ”
- în cazul în care toate lacurile sunt de formă pătrată şi în acelaşi timp „pline de ”, urmează liniile ce descriu drumul de lungime minimă ales. Fiecare linie din fişier conţine câte o pereche de coordonate ale poziţiilor succesive prin care trece drumul (linia şi coloana, separate cu un spaţiu), începând cu şi terminând cu
Restricții și precizări
- Poziţiile şi sunt sigur libere (cu valoarea )
- Dacă există mai multe soluţii se va afişa oricare dintre ele
- Pot fi cel mult de lacuri şi cel puţin unul; dacă un lac este de formă pătrată, atunci . Indiferent de forma lor, lacurile sunt sigur „izolate”, adică nu se „ating” deloc de alt lac. De exemplu, dacă un lac conţine poziţia , atunci un alt lac nu poate conţine vreuna din poziţiile învecinate cu , adică: şi .
Exemplu
lacuri.in
6
0 0 0 0 0 0
0 1 0 1 1 1
0 0 0 1 1 1
0 0 0 1 1 1
1 1 0 0 0 0
1 1 0 0 1 0
lacuri.out
4
1 1
1 2
1 3
2 3
3 3
4 3
5 3
5 4
5 5
5 6
6 6
Explicație
a) Prima linie conţine (sunt lacuri de formă pătrată şi „pline de ”)
b) Deoarece toate cele lacuri sunt de formă pătrată şi „pline de ”, se scrie şi drumul ales: de la .
Observaţii
- Dacă în poziţia ar fi fost un , atunci lacul cu latura nu ar mai fi fost „plin de ” şi atunci prima linie ar fi conţinut doar valoarea (ar fi fost doar lacuri pătrate şi „pline de ”)
- În exemplul iniţial, dacă în poziţia ar fi fost valorea , atunci nu ar fi fost toate lacurile pătrate (cel din stânga-jos nu ar fi fost pătrat) şi s-ar fi afişat doar un în fişierul de ieşire
- În exemplul iniţial, dacă în poziţia ar fi fost valoarea , atunci s-ar fi afişat doar un , pentru că lacul din stânga-jos nu ar fi un lac pătrat şi „plin de ”