Se consideră o matrice cu N linii și N coloane, numerotate de la 1 la N, care memorează doar valori 0 și 1. Se dau de asemenea coordonatele a trei componente din această matrice.
Cerința
Să se determine lungimea minimă a unui drum care pleacă din poziția (1,1), trece obligatoriu prin cele trei componente date (nu contează în ce ordine) și apoi ajunge în poziția (N, N), drum care trece doar prin componente marcate cu 0 și învecinate pe linii și coloane. Un pas din drum constă din deplasarea dintr-un punct (i,j) într-unul din cele patru învecinate pe linie și coloană, adică într-unul din punctele (i-1,j), (i,j-1), (i+1, j), (i,j+1).
Date de intrare
Programul citește de la tastatură numărul N. Pe fiecare din următoarele N linii și N coloane este descrisă matricea binară. Pe ultimele trei linii sunt câte două numere naturale de forma x y ce descriu coordonatele în matrice (linie și coloană) ale celor trei puncte.
Date de ieșire
Programul va afișa pe ecran un singur număr natural, care reprezintă lungimea minimă a drumului care pornește din (1, 1), trece prin cele trei puncte date și ajunge în punctul (N, N).
Restricții și precizări
3 ≤ N ≤ 100- Cele trei puncte sunt distincte, diferite de pozițiile
(1,1)și(N,N)și se găsesc la poziții din matrice marcate cu0. De asemenea, la pozițiile(1,1)și(N,N)se găsește mereu valoarea0. - Pentru datele de intrare va exista mereu soluție, adică există cel puțin un drum de la
(1,1)la(N,N).
Exemplu:
Intrare
4 0 0 0 0 1 0 1 1 0 0 0 1 1 0 0 0 3 3 1 4 3 1
Ieșire
12
Explicație
Cele trei puncte sunt situate în coordonatele (3,3), (1,4), (3,1).
Drumul de lungime minimă este:
- de la
(1,1)la(1,4)(lungime3) - de la
(1,4)la(3,1)(lungime5) - de la
(3,1)la(3,3)(lungime2) - de la
(3,3)la(4,4)(lungime2)
Lungime totală:3 + 5 + 2 + 2 = 12.

